RxJS-퀵 가이드

이 장에서는 RxJS의 기능, 장점 및 단점에 대한 정보를 다룹니다. 여기에서는 RxJS를 사용하는시기도 배웁니다.

RxJS의 전체 형식은 다음과 같습니다. Reactive Extension for Javascript. 비동기 데이터 호출, 콜백 및 이벤트 기반 프로그램을 처리하는 반응 형 프로그래밍 작업을 위해 Observable을 사용하는 자바 스크립트 라이브러리입니다. RxJS는 다른 Javascript 라이브러리 및 프레임 워크와 함께 사용할 수 있습니다. javascript 및 typescript로 지원됩니다.

RxJS 란 무엇입니까?

RxJS 공식 웹 사이트에 따르면 관찰 가능한 시퀀스를 사용하여 비동기 및 이벤트 기반 프로그램을 구성하는 라이브러리로 정의됩니다. 하나의 핵심 유형 인 Observable, 위성 유형 (Observer, Scheduler, Subjects)과 Array # extras (map, filter, reduce, every 등)에서 영감을받은 연산자를 제공하여 비동기 이벤트를 컬렉션으로 처리 할 수 ​​있습니다.

RxJS의 특징

RxJS에서 다음 개념은 비동기 작업을 처리합니다.

주목할 만한

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

관찰자

next (), error () 및 complete () 메서드가있는 객체로, 관찰 대상과 상호 작용할 때 호출됩니다. 즉, 소스가 예제 버튼 클릭, Http 요청 등에 대해 상호 작용합니다.

신청

옵저버 블이 생성되면 옵저버 블을 실행하려면 구독해야합니다. 실행을 취소하는 데 사용할 수도 있습니다.

연산자

연산자는 observable을 입력으로 받아들이고 출력도 observable 인 순수한 함수입니다.

제목

주제는 여러 관찰자와 대화 할 수있는 관찰 대상입니다. 이벤트 리스너가있는 버튼을 생각해 보면, addlistener를 사용하여 이벤트에 연결된 함수는 사용자가 버튼을 클릭 할 때마다 호출됩니다. 비슷한 기능이 주제에도 적용됩니다.

스케줄러

스케줄러는 구독이 시작되고 알림을 받아야하는시기의 실행을 제어합니다.

RxJS를 언제 사용합니까?

프로젝트가 RxJS보다 많은 비동기 작업 처리로 구성된 경우 좋은 선택입니다. Angular 프로젝트와 함께 기본적으로로드됩니다.

RxJS 사용의 장점

다음은 RxJS 사용의 장점입니다-

  • RxJS는 다른 Javascript 라이브러리 및 프레임 워크와 함께 사용할 수 있습니다. javascript 및 typescript로 지원됩니다. Angular, ReactJS, Vuejs, nodejs 등의 예는 거의 없습니다.

  • RxJS는 비동기 작업 처리와 관련하여 멋진 라이브러리입니다 .RxJS는 관찰 가능 항목을 사용하여 비동기 데이터 호출, 콜백 및 이벤트 기반 프로그램을 처리하는 반응 형 프로그래밍 작업을 수행합니다.

  • RxJS는 수학적, 변환, 필터링, 유틸리티, 조건부, 오류 처리, 조인 범주에 대한 방대한 연산자 모음을 제공하여 반응 형 프로그래밍과 함께 사용할 때 생활을 쉽게 만듭니다.

RxJS 사용의 단점

다음은 RxJS 사용의 단점입니다-

  • Observable로 코드를 디버깅하는 것은 거의 어렵지 않습니다.

  • Observable을 사용하기 시작하면 Observable 아래에 전체 코드를 래핑 할 수 있습니다.

이 장에서는 RxJS를 설치할 것입니다. RxJS를 사용하려면 다음 설정이 필요합니다.

  • NodeJS
  • Npm
  • RxJS 패키지 설치

NODEJS 및 NPM 설치

npm을 사용하여 RxJS를 설치하는 것은 매우 쉽습니다. 시스템에 nodejs 및 npm이 설치되어 있어야합니다. NodeJS 및 npm이 시스템에 설치되어 있는지 확인하려면 명령 프롬프트에서 다음 명령을 실행 해보십시오.

E:\>node -v && npm -v
v10.15.1
6.4.1

버전을 얻는 경우에는 nodejs 및 npm이 시스템에 설치되어 있고 버전이 현재 시스템에 10 및 6임을 의미합니다.

아무것도 인쇄되지 않으면 시스템에 nodejs를 설치하십시오. nodejs를 설치하려면 홈페이지로 이동하십시오.https://nodejs.org/en/download/ nodejs의 OS에 따라 패키지를 설치하십시오.

nodejs의 다운로드 페이지는 다음과 같습니다.

OS에 따라 필요한 패키지를 설치하십시오. nodejs가 설치되면 npm도 함께 설치됩니다. npm이 설치되어 있는지 확인하려면 터미널에 npm –v를 입력합니다. npm의 버전이 표시되어야합니다.

RxJS 패키지 설치

RxJS 설치를 시작하려면 먼저 다음 폴더를 만듭니다. rxjsproj/ 모든 RxJS 예제를 연습 할 것입니다.

일단 폴더 rxjsproj/ 생성, 명령 실행 npm init, 아래와 같이 프로젝트 설정 용

E:\>mkdir rxjsproj
E:\>cd rxjsproj
E:\rxjsproj>npm init

Npm init명령은 실행 중에 몇 가지 질문을 할 것입니다. 그냥 Enter 키를 누르고 계속 진행하십시오. npm init 실행이 완료되면package.json 아래와 같이 rxjsproj / 내부-

rxjsproj/
   package.json

이제 아래 명령을 사용하여 rxjs를 설치할 수 있습니다.

npm install ---save-dev rxjs

E:\rxjsproj>npm install --save-dev rxjs
npm notice created a lockfile as package-lock.json. You should commit this file.

npm WARN [email protected] No description
npm WARN [email protected] No repository field.

+ [email protected]
added 2 packages from 7 contributors and audited 2 packages in 21.89s
found 0 vulnerabilities

RxJS 설치가 끝났습니다. 이제 폴더를 생성하기 위해 RxJS를 사용해 보겠습니다.src/ 내부 rxjsproj/

이제 아래와 같은 폴더 구조를 갖게됩니다.

rxjsproj/
   node_modules/
   src/
   package.json

내부 src/ 파일 생성 testrx.js, 다음 코드를 작성하십시오-

testrx.js

import { of } from 'rxjs;
import { map } from 'rxjs/operators';

map(x => x * x)(of(1, 2, 3)).subscribe((v) => console.log(`Output is: ${v}`));

명령 프롬프트에서 위의 코드를 실행할 때 명령을 사용하여- node testrx.js, nodejs는 import로 무엇을 해야할지 모르기 때문에 import 오류를 표시합니다.

nodejs로 가져 오기 작업을 수행하려면 아래와 같이 npm을 사용하여 ES6 모듈 패키지를 설치해야합니다.

E:\rxjsproj\src>npm install --save-dev esm
npm WARN [email protected] No description
npm WARN [email protected] No repository field.

+ [email protected]
added 1 package from 1 contributor and audited 3 packages in 9.32s
found 0 vulnerabilities

패키지가 설치되면 이제 실행할 수 있습니다. testrx.js 아래에 표시된 파일-

E:\rxjsproj\src>node -r esm testrx.js
Output is: 1
Output is: 4
Output is: 9

이제 RxJS가 설치되어 사용할 준비가되었음을 보여주는 출력을 볼 수 있습니다. 위의 방법은 명령 줄에서 RxJS를 테스트하는 데 도움이됩니다. 브라우저에서 RxJS를 테스트하려면 추가 패키지가 필요합니다.

브라우저에서 RxJS 테스트

rxjsproj / 폴더 안에 다음 패키지를 설치하십시오-

npm install --save-dev babel-loader @babel/core @babel/preset-env webpack webpack-cli webpack-dev-server

E:\rxjsproj>npm install --save-dev babel-loader 
@babel/core @babel/preset-env webpack webpack-cli webpack-dev-server

npm WARN [email protected] No description
npm WARN [email protected] No repository field.
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: [email protected]
(node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@
1.2.9: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})

+ [email protected]
+ [email protected]
+ @babel/[email protected]
+ @babel/[email protected]
+ [email protected]
+ [email protected]
added 675 packages from 373 contributors and audited 10225 packages in 255.567s
found 0 vulnerabilities

Html 파일을 실행하기 위해 서버를 시작하려면 webpack-server를 사용합니다. package.json의 "publish"명령은 webpack을 사용하여 모든 js 파일을 시작하고 압축하는 데 도움이됩니다. 사용할 최종 js 파일 인 압축 된 js 파일은 경로 / dev 폴더에 저장됩니다.

웹팩을 사용하려면 다음을 실행해야합니다. npm run publish 명령과 명령은 아래와 같이 package.json에 추가됩니다.

Package.json

{
   "name": "rxjsproj",
   "version": "1.0.0",
   "description": "",
   "main": "index.js",
   "scripts": {
      "publish":"webpack && webpack-dev-server --output-public=/dev/",
      "test": "echo \"Error: no test specified\" && exit 1"
   },
   "author": "",
   "license": "ISC",
   "devDependencies": {
      "@babel/core": "^7.6.0",
      "@babel/preset-env": "^7.6.0",
      "babel-loader": "^8.0.6",
      "esm": "^3.2.25",
      "rxjs": "^6.5.3",
      "webpack": "^4.39.3",
      "webpack-cli": "^3.3.8",
      "webpack-dev-server": "^3.8.0"
   }
}

webpack을 사용하려면 먼저 webpack이 작동하도록 구성 세부 정보가있는 webpack.config.js라는 파일을 만들어야합니다.

파일의 세부 사항은 다음과 같습니다-

var path = require('path');

module.exports = {
   entry: {
      app: './src/testrx.js'
   },
   output: {
      path: path.resolve(__dirname, 'dev'),
      filename: 'main_bundle.js'
   },
   mode:'development',
   module: {
      rules: [
         {
            test:/\.(js)$/,
            include: path.resolve(__dirname, 'src'),
            loader: 'babel-loader',
            query: {
               presets: ['@babel/preset-env']
            }
         }
      ]
   }
};

파일의 구조는 위와 같습니다. 현재 경로 세부 정보를 제공하는 경로로 시작합니다.

var path = require('path'); //gives the current path

다음은 항목, 출력 및 모듈 속성이있는 module.exports 객체입니다. 항목은 시작점입니다. 여기에서 컴파일하려는 시작 js 파일을 제공해야합니다.

entry: {
   app: './src/testrx.js'
},

path.resolve (_dirname, 'src / testrx.js')-디렉토리에서 src 폴더를 찾고 해당 폴더에서 testrx.js를 찾습니다.

산출

output: {
   path: path.resolve(__dirname, 'dev'),
   filename: 'main_bundle.js'
},

출력은 경로와 파일 이름 details.path가있는 개체입니다. 컴파일 된 파일이 보관 될 폴더를 포함하고 파일 이름은 .html 파일에서 사용할 최종 파일의 이름을 알려줍니다.

기준 치수

module: {
   rules: [
      {
         test:/\.(js)$/,
         include: path.resolve(__dirname, 'src'),
         loader: 'babel-loader',
         query: {
            presets: ['@babel/preset-env']
         }
      }
   ]
}

Module테스트, 포함, 로더, 쿼리와 같은 속성이있는 규칙 세부 정보가있는 개체입니다. 테스트는 .js 및 .jsx로 끝나는 모든 js 파일의 세부 정보를 보유합니다. 주어진 진입 점의 끝에서 .js를 찾는 패턴이 있습니다.

Include 파일을 보는 데 사용할 폴더를 알려줍니다.

The loader 코드 컴파일을 위해 babel-loader를 사용합니다.

The query값이 '@ babel / preset-env'인 배열 인 속성 사전 설정이 있습니다. 필요한 ES 환경에 따라 코드를 변환합니다.

최종 폴더 구조는 다음과 같습니다.

rxjsproj/
   node_modules/
   src/
      testrx.js
   index.html
   package.json
   webpack.config.js

명령 실행

npm run publishmain_bundle.js 파일이있는 dev / 폴더를 생성합니다. 서버가 시작되고 아래와 같이 브라우저에서 index.html을 테스트 할 수 있습니다.

브라우저를 열고 URL을 누르십시오- http://localhost:8080/

출력은 콘솔에 표시됩니다.

이 튜토리얼에서는 RxJS 버전 6을 사용하고 있습니다. RxJS는 일반적으로 반응 형 프로그래밍을 처리하는 데 사용되며 Angular, ReactJS에서 더 자주 사용됩니다. Angular 6은 기본적으로 rxjs6을로드합니다.

RxJS 버전 5는 버전 6과 비교하여 다르게 처리되었습니다. RxJS 5를 6으로 업데이트하면 코드가 손상됩니다.이 장에서는 버전 업데이트를 처리하는 방법의 차이점을 살펴 보겠습니다.

RxJS를 6으로 업데이트하고 코드 변경을 원하지 않는 경우에도 그렇게 할 수 있으며 다음 패키지를 설치해야합니다.

npm install --save-dev rxjs-compact

이 패키지는 이전 버전과의 호환성을 제공하고 이전 코드는 RxJS 버전 6에서 잘 작동합니다. RxJS 6에서 잘 작동하는 코드 변경을 수행하려면 다음을 수행해야합니다.

운영자, 관찰 가능 항목, 주제에 대한 패키지가 재구성되었으므로 주요 변경 사항은 수입품에 적용되며 아래에 설명되어 있습니다.

운영자를위한 수입품

버전 5에 따라 연산자의 경우 다음 import 문이 포함되어야합니다.

import 'rxjs/add/operator/mapTo'
import 'rxjs/add/operator/take'
import 'rxjs/add/operator/tap'
import 'rxjs/add/operator/map'

RxJS 버전 6에서 가져 오기는 다음과 같습니다.

import {mapTo, take, tap, map} from "rxjs/operators"

Observable 생성을위한 메소드 가져 오기

버전 5에 따라 Observable로 작업하는 동안 다음 가져 오기 방법이 포함되어야합니다.

import "rxjs/add/observable/from";
import "rxjs/add/observable/of";
import "rxjs/add/observable/fromEvent";
import "rxjs/add/observable/interval";

RxJS 버전 6에서 가져 오기는 다음과 같습니다.

import {from, of, fromEvent, interval} from 'rxjs';

Observable 가져 오기

RxJS 버전 5에서는 Observable로 작업하는 동안 다음 import 문이 포함되어야합니다.

import { Observable } from 'rxjs/Observable'

RxJS 버전 6에서 가져 오기는 다음과 같습니다.

import { Observable } from 'rxjs'

주제 가져 오기

RxJS 버전 5에서 제목은 다음과 같이 포함되어야합니다.

import { Subject} from 'rxjs/Subject'

RxJS 버전 6에서 가져 오기는 다음과 같습니다.

import { Subject } from 'rxjs'

RxJS 6에서 연산자를 사용하는 방법은 무엇입니까?

pipe() method생성 된 Observable에서 사용할 수 있습니다. 버전 5.5부터 RxJS에 추가되었습니다. 이제 pipe ()를 사용하여 여러 연산자를 순차적으로 함께 작업 할 수 있습니다. RxJS 버전 5에서 연산자가 사용 된 방법입니다.

import "rxjs/add/observable/from";
import 'rxjs/add/operator/max'

let list1 = [1, 6, 15, 10, 58, 2, 40];
from(list1).max((a,b)=>a-b).subscribe(x => console.log("The Max value is "+x));

RxJS 버전 5.5부터는 pipe ()를 사용하여 연산자를 실행해야합니다.

import { from } from 'rxjs';
import { max } from 'rxjs/operators';

from(list1).pipe(max((a,b)=>a-b)).subscribe(x => console.log(
   "The Max value is "+x)
);

운영자 이름 변경

패키지를 재구성하는 동안 일부 연산자는 javascript 키워드와 충돌하거나 일치하므로 이름이 변경되었습니다. 목록은 다음과 같습니다.

운영자 다음으로 이름 변경
하다() 꼭지()
잡기() catchError ()
스위치() switchAll ()
드디어() finalize ()
던지다() throwError ()

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"));

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

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

연산자는 RxJS의 중요한 부분입니다. 연산자는 observable을 입력으로 받아들이고 출력도 observable 인 순수한 함수입니다.

운영자와 작업

연산자는 observable을 입력으로 받아들이고 출력도 observable 인 순수한 함수입니다.

연산자로 작업하려면 pipe () 메소드가 필요합니다.

pipe () 사용 예

let obs = of(1,2,3); // an observable
obs.pipe(
   operator1(),
   operator2(),
   operator3(),
   operator3(),
)

위의 예에서 우리는 of()값 1, 2 및 3을받는 메서드입니다. 이제이 Observable에서 위와 같이 pipe () 메서드를 사용하여 여러 연산자를 사용하여 다른 연산을 수행 할 수 있습니다. 연산자의 실행은 주어진 Observable에서 순차적으로 진행됩니다.

아래는 작동 예입니다-

import { of } from 'rxjs';
import { map, reduce, filter } from 'rxjs/operators';

let test1 = of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
let case1 = test1.pipe(
   filter(x => x % 2 === 0),
   reduce((acc, one) => acc + one, 0)
)
case1.subscribe(x => console.log(x));

산출

30

위의 예에서는 짝수를 필터링하는 필터 연산자를 사용했으며 다음으로 reduce() 짝수 값을 추가하고 구독 할 때 결과를 제공하는 연산자입니다.

다음은 우리가 논의 할 Observable 목록입니다.

  • Creation
  • Mathematical
  • Join
  • Transformation
  • Filtering
  • Utility
  • Conditional
  • Multicasting
  • 오류 처리

창조 연산자

다음은 생성 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 아약스

이 연산자는 주어진 URL에 대해 ajax 요청을합니다.

2 ...에서

이 연산자는 배열, 배열 유사 객체, 약속, 반복 가능 객체 또는 관찰 가능 유사 객체에서 관찰 가능 항목을 생성합니다.

fromEvent

이 연산자는 버튼, 클릭 등과 같은 이벤트를 발생시키는 요소에 사용할 관찰 가능 항목으로 출력을 제공합니다.

4 fromEventPattern

이 연산자는 이벤트 핸들러를 등록하는 데 사용되는 입력 함수에서 옵저버 블을 생성합니다.

5 간격

이 연산자는 주어진 시간 동안 매번 Observable을 생성합니다.

6

이 연산자는 전달 된 인수를 가져와 관찰 가능으로 변환합니다.

7 범위

이 연산자는 제공된 범위에 따라 일련의 숫자를 제공하는 Observable을 만듭니다.

8 throwError

이 연산자는 오류를 알리는 옵저버 블을 생성합니다.

9 시간제 노동자

이 연산자는 시간 초과 후 값을 방출하는 관찰 가능 항목을 만들고 각 호출 후 값이 계속 증가합니다.

10 iif

이 연산자는 구독 할 Observable을 결정합니다.

수학 연산자

다음은 수학 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 카운트

count () 연산자는 값이있는 Observable을 가져 와서 단일 값을 제공하는 Observable로 변환합니다.

2 최대

Max 메서드는 모든 값이있는 Observable을 가져 와서 max 값을 가진 Observable을 반환합니다.

최소

Min 메서드는 모든 값이있는 Observable을 가져 와서 min 값으로 Observable을 반환합니다.

4 줄이다

reduce 연산자에서 누산기 함수는 입력 관찰 가능 항목에 사용되며 누산기 함수는 누산기 함수에 전달 된 선택적 시드 값과 함께 관찰 가능 형식으로 누적 된 값을 반환합니다.

reduce () 함수는 2 개의 인수, 하나의 누산기 함수, 두 번째는 시드 값을받습니다.

조인 연산자

다음은 Join 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 연결

이 연산자는 입력으로 주어진 Observable을 순차적으로 방출하고 다음으로 진행합니다.

2 forkJoin

이 연산자는 배열 또는 dict 객체에서 입력으로 취해지며 옵저버 블이 완료 될 때까지 기다렸다가 주어진 옵저버 블에서 방출 된 마지막 값을 반환합니다.

병합

이 연산자는 Observable 입력을 받고 Observable에서 모든 값을 방출하고 하나의 Observable 출력을 방출합니다.

4 경주

관찰 가능한 첫 번째 소스의 미러 사본이 될 관찰 대상을 돌려줍니다.

변환 연산자

다음은 변환 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 완충기

버퍼는 관찰 가능 항목에서 작동하며 관찰 가능 항목으로 인수를받습니다. 배열의 원래 Observable에서 방출 된 값을 버퍼링하기 시작하고 인수로 취해진 Observable이 방출 될 때 동일한 것을 방출합니다. 인수로 취해진 관찰 가능 항목이 방출되면 버퍼가 재설정되고 입력 관찰 가능 항목이 방출되고 동일한 시나리오가 반복 될 때까지 원본에서 다시 버퍼링을 시작합니다.

2 bufferCount

buffercount () 연산자의 경우 호출 된 Observable에서 값을 수집하고 buffercount에 지정된 버퍼 크기가 일치 할 때 동일한 값을 내 보냅니다.

bufferTime

이는 bufferCount와 유사하므로 여기에서 호출되는 Observable에서 값을 수집하고 bufferTimeSpan이 완료되는 것을 내 보냅니다. 그것은 하나의 인수 즉 bufferTimeSpan을 받습니다.

4 bufferToggle

bufferToggle ()의 경우 2 개의 인수, openings 및 closingSelector를 사용합니다. 여는 인수는 구독 가능하거나 버퍼를 시작하겠다는 약속이고 두 번째 인수 closedSelector는 다시 구독 가능하거나 표시기를 약속하여 버퍼를 닫고 수집 된 값을 방출합니다.

5 버퍼

이 연산자는 배열 형식으로 값을 제공하며 버퍼를 닫고, 내보내고 재설정 할시기를 결정하는 함수로 하나의 인수를받습니다.

6 넓히다

확장 연산자는 관찰 가능한 소스와 관찰 가능한 출력에도 적용되는 인수로 함수를받습니다. 최종 값은 관찰 가능합니다.

7 groupBy

groupBy 연산자에서 출력은 특정 조건에 따라 그룹화되며 이러한 그룹 항목은 GroupedObservable로 내보내집니다.

8 지도

맵 연산자의 경우 소스 Observable의 각 값에 프로젝트 함수가 적용되고 동일한 출력이 Observable로 방출됩니다.

9 mapTo

소스 Observable이 값을 내보낼 때마다 Observable과 함께 상수 값이 출력으로 제공됩니다.

10 mergeMap

mergeMap 연산자의 경우 각 소스 값에 프로젝트 함수가 적용되고 그 출력이 Observable 출력과 병합됩니다.

11 switchMap

switchMap 연산자의 경우 각 소스 값에 프로젝트 함수가 적용되고 그 출력은 Observable 출력과 병합되며 주어진 값은 가장 최근에 투영 된 Observable입니다.

12 창문

관찰 가능한 인수 windowboundaries를 취하고 주어진 windowboundaries가 방출 할 때마다 중첩 된 Observable을 돌려줍니다.

필터링 연산자

다음은 필터링 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 디 바운스

잠시 후 Observable 소스에서 방출 된 값과 방출은 Observable 또는 promise로 지정된 다른 입력에 의해 결정됩니다.

2 debounceTime

시간이 완료된 후에 만 ​​관찰 가능한 소스에서 값을 방출합니다.

뚜렷한

이 연산자는 이전 값과 비교할 때 구별되는 관찰 가능한 소스의 모든 값을 제공합니다.

4 elementAt

이 연산자는 주어진 인덱스를 기반으로 관찰 가능한 소스에서 단일 값을 제공합니다.

5 필터

이 연산자는 주어진 조건 자 함수를 기반으로 소스 Observable에서 값을 필터링합니다.

6 먼저

이 연산자는 Observable 소스가 내 보낸 첫 번째 값을 제공합니다.

7 마지막

이 연산자는 Observable 소스가 내 보낸 마지막 값을 제공합니다.

8 ignoreElements

이 연산자는 소스 Observable의 모든 값을 무시하고 완료 또는 오류 콜백 함수 호출 만 실행합니다.

9 견본

이 연산자는 소스 Observable에서 가장 최근 값을 제공하며 출력은 전달 된 인수에 따라 다릅니다.

10 건너 뛰기

이 연산자는 입력으로 취해진 카운트 항목의 첫 번째 발생을 건너 뛰는 관찰 가능 항목을 반환합니다.

11 조절판

이 연산자는 인수로 취해진 입력 함수에 의해 결정된 시간 동안 관찰 가능한 소스의 값을 출력하고 무시하며 동일한 프로세스가 반복됩니다.

유틸리티 운영자

다음은 유틸리티 운영자 카테고리에서 논의 할 운영자입니다.

Sr. 아니요 연산자 및 설명
1 꼭지

이 연산자는 소스 관찰 가능과 동일한 출력을 가지며 관찰 가능 항목에서 사용자에게 값을 기록하는 데 사용할 수 있습니다. 주요 값, 오류 (있는 경우) 또는 작업이 완료된 경우.

2 지연

이 연산자는 주어진 시간 초과에 따라 소스 Observable에서 방출되는 값을 지연시킵니다.

delayWhen

이 연산자는 입력으로 사용 된 다른 Observable의 시간 초과를 기반으로 소스 Observable에서 방출되는 값을 지연시킵니다.

4 관찰하다

입력 스케줄러를 기반으로하는이 연산자는 소스 Observable에서 알림을 다시 보냅니다.

5 subscribeOn

이 연산자는 입력으로 사용 된 스케줄러를 기반으로 소스 Observable에 대한 비동기 구독을 돕습니다.

6 timeInterval

이 연산자는 취해진 스케줄러 입력을 사용하여 계산 된 현재 값과 현재 값과 이전 값 사이에 경과 된 시간을 포함하는 객체를 반환합니다.

7 타임 스탬프

값이 방출 된 시간을 알려주는 소스 Observable에서 방출 된 값과 함께 타임 스탬프를 반환합니다.

8 타임 아웃

이 연산자는 소스 Observable이 주어진 시간 초과 후에 값을 내 보내지 않으면 오류를 발생시킵니다.

9 toArray

Observable에서 모든 소스 값을 누적하고 소스가 완료되면 배열로 출력합니다.

조건부 연산자

다음은 조건부 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 defaultIfEmpty

이 연산자는 관찰 가능한 소스가 비어있는 경우 기본값을 반환합니다.

2 ...마다

소스 Observable의 각 값에 대한 조건을 충족하는 입력 함수를 기반으로 Observable을 반환합니다.

찾기

소스 Observable의 첫 번째 값이 입력으로 취해진 술어 함수의 조건을 충족 할 때 관찰 가능을 리턴합니다.

4 findIndex

입력 스케줄러를 기반으로하는이 연산자는 소스 Observable에서 알림을 다시 보냅니다.

5 비었다

이 연산자는 입력 관찰 가능 항목이 값을 내 보내지 않고 완전한 콜백으로 이동하면 출력을 true로, 입력 관찰 가능 항목이 값을 내 보내면 false를 제공합니다.

멀티 캐스팅 연산자

다음은 멀티 캐스팅 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 멀티 캐스트

멀티 캐스트 운영자는 생성 된 단일 구독을 다른 구독자와 공유합니다. 멀티 캐스트가받는 매개 변수는 connect () 메서드가있는 ConnectableObservable을 반환하는 주체 또는 팩토리 메서드입니다. 구독하려면 connect () 메서드를 호출해야합니다.

2 출판하다

이 연산자는 ConnectableObservable을 반환하고 connect () 메서드를 사용하여 옵저버 블을 구독해야합니다.

publishBehavior

publishBehaviour는 BehaviourSubject를 사용하고 ConnectableObservable을 반환합니다. 생성 된 옵저버 블을 구독하려면 connect () 메서드를 사용해야합니다.

4 publishLast

publishBehaviour는 AsyncSubject를 사용하고 ConnectableObservable을 다시 반환합니다. 생성 된 옵저버 블을 구독하려면 connect () 메서드를 사용해야합니다.

5 publishReplay

publishReplay는 값을 버퍼링하고 새 구독자에게 동일하게 재생할 수있는 동작 주제를 사용하고 ConnectableObservable을 반환합니다. 생성 된 옵저버 블을 구독하려면 connect () 메서드를 사용해야합니다.

6 공유

mutlicast () 연산자의 별칭이지만 구독을 시작하기 위해 수동으로 connect () 메서드를 호출 할 필요가 없다는 점만 다릅니다.

오류 처리 연산자

다음은 오류 처리 연산자 범주에서 논의 할 연산자입니다.

Sr. 아니요 연산자 및 설명
1 catchError

이 연산자는 새 Observable 또는 오류를 반환하여 소스 Observable에서 오류를 잡는 작업을 처리합니다.

2 다시 해 보다

이 연산자는 오류가있는 경우 소스 Observable에서 재 시도를 처리하고 제공된 입력 횟수에 따라 재 시도를 수행합니다.

옵저버 블이 생성되면 옵저버 블을 실행하려면 구독해야합니다.

count () 연산자

다음은 Observable을 구독하는 방법에 대한 간단한 예입니다.

예 1

import { of } from 'rxjs';
import { count } from 'rxjs/operators';

let all_nums = of(1, 7, 5, 10, 10, 20);
let final_val = all_nums.pipe(count());
final_val.subscribe(x => console.log("The count is "+x));

산출

The count is 6

구독에는 unsubscribe ()라는 하나의 메서드가 있습니다. unsubscribe () 메서드를 호출하면 해당 Observable에 사용 된 모든 리소스가 제거됩니다. 즉, Observable이 취소됩니다. 다음은 unsubscribe () 메서드를 사용하는 작업 예제입니다.

예 2

import { of } from 'rxjs';
import { count } from 'rxjs/operators';

let all_nums = of(1, 7, 5, 10, 10, 20);
let final_val = all_nums.pipe(count());
let test = final_val.subscribe(x => console.log("The count is "+x));
test.unsubscribe();

구독은 변수 테스트에 저장됩니다. 관찰 가능한 test.unsubscribe ()를 사용했습니다.

산출

The count is 6

주제는 여러 관찰자와 대화 할 수있는 관찰 대상입니다. 이벤트 리스너가있는 버튼을 생각해 보면, 리스너 추가를 사용하여 이벤트에 첨부 된 함수는 사용자가 버튼을 클릭 할 때마다 유사한 기능이 주제에 대해서도 호출됩니다.

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

  • 주제 만들기
  • Observable과 Subject의 차이점은 무엇입니까?
  • 행동 주제
  • 재생 주제
  • AsyncSubject

주제 만들기

주제로 작업하려면 아래와 같이 주제를 가져와야합니다.

import { Subject } from 'rxjs';

다음과 같이 주제 객체를 만들 수 있습니다-

const subject_test = new Subject();

객체는 세 가지 방법이있는 관찰자입니다.

  • next(v)
  • error(e)
  • complete()

주제 구독

다음과 같이 주제에 대해 여러 구독을 만들 수 있습니다.

subject_test.subscribe({
   next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
   next: (v) => console.log(`From Subject: ${v}`)
});

구독은 앞서 논의한 addlistener와 마찬가지로 주제 객체에 등록됩니다.

주제에 데이터 전달

next () 메서드를 사용하여 생성 된 주제에 데이터를 전달할 수 있습니다.

subject_test.next("A");

데이터는 주제에 추가 된 모든 구독으로 전달됩니다.

여기에 주제의 작동 예가 있습니다-

import { Subject } from 'rxjs';

const subject_test = new Subject();

subject_test.subscribe({
   next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
   next: (v) => console.log(`From Subject: ${v}`)
});
subject_test.next("A");
subject_test.next("B");

subject_test 객체는 new Subject ()를 호출하여 생성됩니다. subject_test 객체에는 next (), error () 및 complete () 메서드에 대한 참조가 있습니다. 위 예의 출력은 다음과 같습니다.

산출

다음과 같이 complete () 메서드를 사용하여 주체 실행을 중지 할 수 있습니다.

import { Subject } from 'rxjs';

const subject_test = new Subject();

subject_test.subscribe({
   next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
   next: (v) => console.log(`From Subject: ${v}`)
});
subject_test.next("A");
subject_test.complete();
subject_test.next("B");

complete를 호출하면 나중에 호출되는 다음 메소드가 호출되지 않습니다.

산출

이제 error () 메서드를 호출하는 방법을 살펴 보겠습니다.

아래는 작동 예입니다-

import { Subject } from 'rxjs';

const subject_test = new Subject();

subject_test.subscribe({
   error: (e) => console.log(`From Subject : ${e}`)
});
subject_test.subscribe({
   error: (e) => console.log(`From Subject : ${e}`)
});
subject_test.error(new Error("There is an error"));

산출

Observable과 Subject의 차이점은 무엇입니까?

Observable은 가입자에게 일대일로 이야기합니다. Observable을 구독 할 때마다 실행이 처음부터 시작됩니다. ajax를 사용하여 만든 Http 호출과 Observable을 호출하는 2 명의 가입자를 가져옵니다. 브라우저 네트워크 탭에 2 개의 HttpHttp 요청이 표시됩니다.

다음은 동일한 작업 예입니다.

import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';

let final_val = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
let subscriber1 = final_val.subscribe(a => console.log(a));
let subscriber2 = final_val.subscribe(a => console.log(a));

산출

자, 여기서 문제는 동일한 데이터가 공유되기를 원하지만 두 번의 Http 호출 비용으로 공유되지 않기를 원한다는 것입니다. 우리는 하나의 Http 호출을 만들고 가입자간에 데이터를 공유하려고합니다.

이것은 주제를 사용하여 가능합니다. 멀티 캐스트, 즉 많은 관찰자와 대화 할 수있는 관찰 가능 항목입니다. 가입자간에 가치를 공유 할 수 있습니다.

다음은 주제를 사용한 작업 예입니다.

import { Subject } from 'rxjs';
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';

const subject_test = new Subject();

subject_test.subscribe({
   next: (v) => console.log(v)
});
subject_test.subscribe({
   next: (v) => console.log(v)
});

let final_val = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
let subscriber = final_val.subscribe(subject_test);

산출

이제 하나의 Http 호출 만 볼 수 있으며 호출 된 구독자간에 동일한 데이터가 공유됩니다.

행동 주제

행동 주제는 호출시 최신 가치를 제공합니다.

아래와 같이 행동 주제를 만들 수 있습니다.

import { BehaviorSubject } from 'rxjs';
const subject = new BehaviorSubject("Testing Behaviour Subject"); 
// initialized the behaviour subject with value:Testing Behaviour Subject

다음은 Behavior Subject를 사용하는 작업 예입니다.

import { BehaviorSubject } from 'rxjs';
const behavior_subject = new BehaviorSubject("Testing Behaviour Subject"); 
// 0 is the initial value

behavior_subject.subscribe({
   next: (v) => console.log(`observerA: ${v}`)
});

behavior_subject.next("Hello");
behavior_subject.subscribe({
   next: (v) => console.log(`observerB: ${v}`)
});
behavior_subject.next("Last call to Behaviour Subject");

산출

재생 주제

replaysubject는 행동 주체와 유사하며, 값을 버퍼링하고 새 구독자에게 동일하게 재생할 수 있습니다.

다음은 재생 주제의 작동 예입니다.

import { ReplaySubject } from 'rxjs';
const replay_subject = new ReplaySubject(2); 
// buffer 2 values but new subscribers

replay_subject.subscribe({
   next: (v) => console.log(`Testing Replay Subject A: ${v}`)
});

replay_subject.next(1);
replay_subject.next(2);
replay_subject.next(3);
replay_subject.subscribe({
   next: (v) => console.log(`Testing Replay Subject B: ${v}`)
});

replay_subject.next(5);

사용 된 버퍼 값은 재생 주제에서 2입니다. 따라서 마지막 두 값은 버퍼링되어 호출 된 새 구독자에 사용됩니다.

산출

AsyncSubject

AsyncSubject의 경우 마지막으로 호출 된 값이 구독자에게 전달되고 complete () 메서드가 호출 된 후에 만 ​​수행됩니다.

다음은 동일한 작업 예입니다.

import { AsyncSubject } from 'rxjs';

const async_subject = new AsyncSubject();

async_subject.subscribe({
   next: (v) => console.log(`Testing Async Subject A: ${v}`)
});

async_subject.next(1);
async_subject.next(2);
async_subject.complete();
async_subject.subscribe({
   next: (v) => console.log(`Testing Async Subject B: ${v}`)
});

여기서 완료를 호출하기 전에 주제에 전달 된 마지막 값은 2이고 구독자에게 주어진 것과 동일합니다.

산출

스케줄러는 구독이 시작되고 알림을 받아야하는시기의 실행을 제어합니다.

스케줄러를 사용하려면 다음이 필요합니다.

import { Observable, asyncScheduler } from 'rxjs';
import { observeOn } from 'rxjs/operators';

다음은 실행을 결정하는 스케줄러를 사용하는 작업 예제입니다.

import { Observable, asyncScheduler } from 'rxjs';
import { observeOn } from 'rxjs/operators';

var observable = new Observable(function subscribe(subscriber) {
   subscriber.next("My First Observable");
   subscriber.next("Testing Observable");
   subscriber.complete();
}).pipe(
   observeOn(asyncScheduler)
);
console.log("Observable Created");
observable.subscribe(
   x => console.log(x),
   (e)=>console.log(e),
   ()=>console.log("Observable is complete")
);

console.log('Observable Subscribed');

산출

스케줄러가 없으면 출력은 다음과 같을 것입니다.

이 장에서는 Angular와 함께 RxJ를 사용하는 방법을 살펴 보겠습니다. Angular 설치에 대해 알기 위해 여기에서 Angular의 설치 과정에 들어 가지 않을 것입니다.https://www.tutorialspoint.com/angular7/angular7_environment_setup.htm

RxJS에서 Ajax를 사용하여 데이터를로드하는 예제를 직접 작업하겠습니다.

app.component.ts

import { Component } from '@angular/core';
import { environment } from './../environments/environment';
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators'

@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = '';
   data;
   constructor() {
      this.data = "";
      this.title = "Using RxJs with Angular";
      let a = this.getData();
   }
   getData() {
      const response =
      ajax('https://jsonplaceholder.typicode.com/users')
         .pipe(map(e => e.response));
      response.subscribe(res => {
         console.log(res);
         this.data = res;
      });
   }
}

app.component.html

<div>
   <h3>{{title}}</h3>
   <ul *ngFor="let i of data">
      <li>{{i.id}}: {{i.name}}</li>
   </ul>
</div>

<router-outlet></router-outlet>

이 URL에서 데이터를로드하는 RxJS의 ajax를 사용했습니다.https://jsonplaceholder.typicode.com/users.

컴파일하면 아래와 같이 표시됩니다.

이 장에서는 ReactJS와 함께 RxJ를 사용하는 방법을 볼 것입니다. 여기서 Reactjs의 설치 프로세스에 들어 가지 않을 것입니다. ReactJS 설치에 대해 알기 위해 다음 링크를 참조하십시오.https://www.tutorialspoint.com/reactjs/reactjs_environment_setup.htm

RxJS의 Ajax를 사용하여 데이터를로드하는 아래 예제에서 직접 작업 할 것입니다.

index.js

import React, { Component } from "react";
import ReactDOM from "react-dom";
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';
class App extends Component {
   constructor() {
      super();
      this.state = { data: [] };
   }
   componentDidMount() {
      const response = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
      response.subscribe(res => {
         this.setState({ data: res });
      });
   }
   render() {
      return (
         <div>
            <h3>Using RxJS with ReactJS</h3>
            <ul>
               {this.state.data.map(el => (
                  <li>
                     {el.id}: {el.name}
                  </li>
               ))}
            </ul>
         </div>
      );
   }
}
ReactDOM.render(<App />, document.getElementById("root"));

index.html

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "UTF-8" />
      <title>ReactJS Demo</title>
   <head>
   <body>
      <div id = "root"></div>
   </body>
</html>

이 URL에서 데이터를로드하는 RxJS에서 ajax를 사용했습니다.https://jsonplaceholder.typicode.com/users.

컴파일하면 다음과 같이 표시됩니다.