Невозможно использовать операторы фильтра rxjs в angular4 - PullRequest
0 голосов
/ 29 ноября 2018

я пытаюсь использовать фильтр в angular 4, это мой код

import { Component, OnInit } from '@angular/core';
import { range } from 'rxjs/observable/range';
import { map, scan, filter, tap } from 'rxjs/operators';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html'
})
export class AppComponent implements OnInit {  

  ngOnInit(){
    this.rxjs();
  }
  rxjs(){
    const source$ = range(1, 10);

    source$.pipe(
      filter(n => n % 2 !== 0), 
      tap(n => console.log('filtered value: ' + n)),
      map(n => n * n),
      tap(n => console.log('squared value: ' + n)),
      scan((acc,s) => acc + s, 0)
    )
    .subscribe(v => console.log(`sum of squared values : ${v}`));    
  }    
}

это моя угловая версия, которую я узнал, используя команду ng --version

@angular/cli: 1.4.10
node: 8.9.1
os: win32 x64
@angular/animations: 4.4.7
@angular/common: 4.4.7
@angular/compiler: 4.4.7
@angular/core: 4.4.7
@angular/forms: 4.4.7
@angular/http: 4.4.7
@angular/platform-browser: 4.4.7
@angular/platform-browser-dynamic: 4.4.7
@angular/router: 4.4.7
@angular/cli: 1.4.10
@angular/compiler-cli: 4.4.7
@angular/language-service: 4.4.7
typescript: 2.3.4

но когда я компилирую, я получаю такую ​​ошибку

ОШИБКА в E: /angular-mock/routes/src/app/app.component.ts (19, 19): левая часть арифметической операции должна иметь тип 'any', 'number' или тип enum.

Может кто-нибудь помочь мне в том, что я делаю неправильно в этом

Ответы [ 2 ]

0 голосов
/ 29 ноября 2018

я решил проблему, установив rxjs @ 6 и установив rxjs-compat @ 6 для обратной совместимости

 npm install rxjs@6 rxjs-compat@6 --save
0 голосов
/ 29 ноября 2018

Вам необходимо установить RxJS, чтобы использовать эту библиотеку

$ npm i rxjs

Если вам нужна обратная совместимость для старыхпроекты или зависимости, которые не обновлены до версии 6, но используют слишком компактный

$ npm i rxjs-compat

Прочитайте подробное руководство по миграции:

https://github.com/ReactiveX/rxjs/blob/master/docs_app/content/guide/v6/migration.md

Демонстрация:

$ npm i rxjs rxjs-compat

См. Также:

https://rxjs -dev.firebaseapp.com

https://github.com/ReactiveX/rxjs

...