RxJS-관찰 가능 항목

Observable은 옵저버를 생성하고 값이 예상되는 소스에 연결하는 함수입니다 (예 : 클릭, dom 요소 또는 Http 요청의 마우스 이벤트 등).

Observer is an object with callback functions, Observable에 대한 상호 작용이있을 때 호출됩니다. 즉, 소스가 예제 버튼 클릭, Http 요청 등에 대해 상호 작용했습니다.

이 장에서는 다음 주제에 대해 논의 할 것입니다.

  • Observable 만들기
  • Observable 구독
  • Observable 실행

Observable 만들기

Observable은 Observable 생성자를 사용하고 Observable create 메서드를 사용하고 subscribe 함수를 인수로 전달하여 아래와 같이 만들 수 있습니다.

testrx.js

import { Observable } from 'rxjs';

var observable = new Observable(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);

Observable을 생성하고 "My First Observable"메시지를 추가했습니다. subscriber.next Observable 내에서 사용할 수있는 메소드.

다음과 같이 Observable.create () 메서드를 사용하여 Observable을 만들 수도 있습니다.

testrx.js

import { Observable } from 'rxjs';
var observer = Observable.create(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);

Observable 구독

다음과 같이 Observable을 구독 할 수 있습니다.

testrx.js

import { Observable } from 'rxjs';

var observer = new Observable(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);
observer.subscribe(x => console.log(x));

옵저버가 구독되면 옵저버 블 실행이 시작됩니다.

이것이 우리가 브라우저 콘솔에서 보는 것입니다.

Observable 실행

옵저버 블은 구독 할 때 실행됩니다. 관찰자는 알림을받는 세 가지 메서드가있는 개체입니다.

next() −이 방법은 숫자, 문자열, 객체 등과 같은 값을 보냅니다.

complete() −이 방법은 값을 보내지 않으며 옵저버 블이 완료된 것으로 표시합니다.

error() −이 방법은 오류가있는 경우 전송합니다.

세 가지 알림을 모두 사용하여 Observable을 생성하고 동일하게 실행하겠습니다.

testrx.js

import { Observable } from 'rxjs';
var observer = new Observable(
   function subscribe(subscriber) {
      try {
         subscriber.next("My First Observable");
         subscriber.next("Testing Observable");
         subscriber.complete();
      } catch(e){
         subscriber.error(e);
      }
   }
);
observer.subscribe(x => console.log(x), (e)=>console.log(e), 
   ()=>console.log("Observable is complete"));

위의 코드에서 다음, 완료 및 오류 메소드를 추가했습니다.

try{
   subscriber.next("My First Observable");
   subscriber.next("Testing Observable");
   subscriber.complete();
} catch(e){
   subscriber.error(e);
}

다음, 완료 및 오류를 실행하려면 아래와 같이 subscribe 메서드를 호출해야합니다.

observer.subscribe(x => console.log(x), (e)=>console.log(e), 
   ()=>console.log("Observable is complete"));

오류 메소드는 오류가있는 경우에만 호출됩니다.

이것은 브라우저에 표시되는 출력입니다.