新建一个Angular应用,类型选择RxJS:
data:image/s3,"s3://crabby-images/a8d40/a8d4038028dffd36d312ff06cb9ed2b1cf604496" alt=""
StackBlitz会自动生成应用模板:
data:image/s3,"s3://crabby-images/a6e0d/a6e0d7cef826c556f5515e78ef23f1ef2fee7e68" alt=""
源代码:
import { of } from 'rxjs';
import { map } from 'rxjs/operators';
const source = of('World').pipe(
map(x => `Hello ${x}!`)
);
source.subscribe(console.log);
import { Observable } from "rxjs";
const stream$ = new Observable(subscriber => {
setTimeout(() => {
subscriber.next([1, 2, 3]);
}, 500);
setTimeout(() => {
subscriber.next({ a: 1000 });
}, 1000);
setTimeout(() => {
subscriber.next("end");
}, 3000);
setTimeout(() => {
subscriber.complete();
}, 4000);
});
// 启动流
class Subscriber {
constructor(private name: string) {}
complete = () => console.log("name: " + this.name + " done");
next = v =>
console.log("time: " + Date.now() + " name: " + this.name + " value: " + v);
error = () => console.log("error");
}
const s1 = new Subscriber("Jerry");
const s2 = new Subscriber("Tom");
stream$.subscribe(s1);
stream$.subscribe(s2);
运行输出:
data:image/s3,"s3://crabby-images/47c7d/47c7d5ebd264b09bb35b07a727a4a5656e47eb3b" alt=""
Observable可以重复subscribe,互不干扰。
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""
网友评论