RxJS会随着时间的推移发出数组项吗?

Bry*_*yce 19 rxjs

我试图一个接一个地发出简单的数组值,中间有500毫秒:

var a = Rx.Observable.from([1,2,3]);
a.interval(500).subscribe(function(b) { console.log(b); });
Run Code Online (Sandbox Code Playgroud)

但是,这引发了一个例外:

Uncaught TypeError: a.interval is not a function.
Run Code Online (Sandbox Code Playgroud)

Oli*_*old 16

正如xgrommx已经指出的那样,interval它不是可观察的实例成员,而是静态成员Rx.Observable.

Rx.Observable.fromArray([1,2,3]).zip(
  Rx.Observable.interval(500), function(a, b) { return a; })
.subscribe(
  function(x) { document.write(x + '<br \>'); },  
  null,  
  function() { document.write("complete"); });
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/rxjs/2.5.2/rx.all.min.js"></script>
Run Code Online (Sandbox Code Playgroud)


Mic*_*zos 13

使用RxJS版本6的三种方法:

1.使用 concatMap

import { from, of, pipe } from 'rxjs';
import { concatMap, delay } from 'rxjs/operators';

const array = [1, 2, 3, 4, 5];

from(array)
 .pipe(
   concatMap(val => of(val).pipe(delay(1000))),
 )
 .subscribe(console.log);
Run Code Online (Sandbox Code Playgroud)

2.使用zipinterval

import { from, pipe, interval } from 'rxjs';
import { delay, zip} from 'rxjs/operators';

const array = [1, 2, 3, 4, 5];

from(array)
 .pipe(
   zip(interval(1000), (a, b) => a),
 )
 .subscribe(console.log);
Run Code Online (Sandbox Code Playgroud)

3. interval用作来源

import { interval, pipe } from 'rxjs';
import { map, take } from 'rxjs/operators';

const array = [1, 2, 3, 4, 5];

interval(1000)
.pipe(
  take(array.length),
  map(i => array[i])
)
.subscribe(console.log);
Run Code Online (Sandbox Code Playgroud)

  • 谨防!`zip` 运算符已被弃用,以支持静态 zip!来源:https://rxjs-dev.firebaseapp.com/api/operators/zip 所以它变成了:```import { zip } from 'rxjs'; zip(interval(1000), from(array)).map((a, b) =&gt; a).subscribe(...)``` (3认同)

pix*_*its 9

我就是这样做的:

var fruits = ['apple', 'orange', 'banana', 'apple'];
var observable = Rx.Observable.interval(1000).take(fruits.length).map(t => fruits[t]);
observable.subscribe(t => {
  console.log(t);
  document.body.appendChild(document.createTextNode(t + ', '));
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/rxjs/2.5.2/rx.all.min.js"></script>
Run Code Online (Sandbox Code Playgroud)