angular Observable
1.回调函数
/** 1.设计实现函数 */
print_msg(msg) {
console.log(msg);
} /** 2.设计调用函数,param1:实现函数参数,param2:实现函数本身 */
async_read(msg, callback) {
callback(msg);
} constructor() {
/** 3.调用 调用函数 */
this.async_read('我要打印的消息', this.print_msg);
}
这样做可以通过3给2传入不同的函数名而实现不同的操作。
2.Promise
study_promise() {
const p = new Promise(resolve => {
resolve('成功回调');
}).then((res) => {
console.log(res);
return res;
}).then((res) => {
console.log(res);
});
}
3.Observable

3.1先写一个简单的例子,5s内每隔一秒打印一次‘hello’
constructor() {
this.study_observable()
.subscribe((res) => {
console.log(res);
});
}
study_observable(): Observable<string> {
let i = ;
return Observable.create((observer) => {
setInterval(() => {
i++;
observer.next('hello_' + i);
if (i === ) {
observer.complete();
}
}, );
});
}
3.2 of创建Observable 并订阅一个Observer
ngOnInit() {
this.getdata();
}
getdata() {
const myObservable = of(, , );
const myObserver = {
next: x => console.log('next' + x),
error: err => console.error('error' + err),
complete: () => console.log('complete')
};
myObservable.subscribe(myObserver);
}
of创建一个可观察对象,上面的代码等价于
ngOnInit() {
this.getdata();
}
getdata() {
// const myObservable = of(1, 2, 3);
const myObservable = new Observable(this.sequenceSubscriber);
const myObserver = {
next: x => console.log('next' + x),
error: err => console.error('error' + err),
complete: () => console.log('complete')
};
myObservable.subscribe(myObserver);
}
sequenceSubscriber(observer: Observer<any>) {
observer.next();
observer.next();
observer.next();
observer.complete();
return { unsubscribe() { } };
}
3.3 页面 Async 管道
<div>{{time$ | async}}</div>
这样写就相当于订阅了time$,会实时接收next过来的值,
Observable定义如下,用来逐秒打印时间,
页面接收的值类型为Observable<T>,下方为string
time$: Observable<string>;
ngOnInit() {
this.time$ = new Observable(observer => {
setInterval(() => {
observer.next(new Date().toString());
}, );
});
}
若是要接收object对象,需要这样取值
<ng-container *ngIf="time$ | async as time">
<div>
{{time.date}}
{{time.time}}
</div>
</ng-container>
ts:
time$: Observable<object>;
ngOnInit() {
this.time$ = new Observable(observer => {
setInterval(() => {
const e = new Date();
observer.next({ date: e.toDateString(), time: e.toTimeString() });
}, );
});
}
3.4 Object
既可以作为Observable、也可以作为Observer
支持多播
constructor() {
const subject = new Subject();
/*作为被观察者 支持多播 可以订阅多个观察者 */
subject.subscribe(
{
next: x => console.log('A:' + x)
}
);
subject.subscribe(
{
next: x => console.log('B:' + x)
}
);
/*发送值 */
subject.next();
subject.next();
/*Subject作为观察者,可以被Observalbe订阅 */
const fo = of(, , );
fo.subscribe(subject);
}
结果:

3.5 BehaviorSubject 是 Subject的子类
它有一个“当前值”的概念,保存了发送给消费者的最新值。
并且当有新的观察者订阅时,会立即从 BehaviorSubject 那接收到“当前值”。
constructor() {
const bs = new BehaviorSubject(); // 给一个当前值(初始值)
bs.subscribe({
next: v => console.log('A' + v),
});
bs.next();
bs.subscribe({
next: v => console.log('B' + v)
});
bs.next();
}
结果:

3.6 ReplaySubject 是Subject的子类
发送旧值给新的订阅者
constructor() {
const bs = new ReplaySubject(); // 回放三个值
bs.subscribe({
next: v => console.log('A' + v),
});
bs.next();
bs.next();
bs.next();
bs.next();
bs.subscribe({
next: v => console.log('B' + v)
});
bs.next();
}
结果:

3.7 AsyncSubject 是Subject的子类
只有当 Observable 执行完成时(执行 complete()),它才会将执行的最后一个值发送给观察者。
constructor() {
const bs = new AsyncSubject();
bs.subscribe({
next: v => console.log('A' + v),
});
bs.next();
bs.next();
bs.next();
bs.next();
bs.subscribe({
next: v => console.log('B' + v)
});
bs.complete();
bs.next();
}
结果:

angular Observable的更多相关文章
- [Angular] Observable.catch error handling in Angular
import { Observable } from 'rxjs/Observable'; import 'rxjs/add/operator/map'; import 'rxjs/add/opera ...
- [Angular 2] Rendering an Observable with the Async Pipe
Angular 2 templates use a special Async pipe to be able to render out Observables. This lesson cover ...
- Angular基础(八) Observable & RxJS
对于一个应用来说,获取数据的方法可以有很多,比如:Ajax, Websockets, LocalStorage, Indexdb, Service Workers,但是如何整合多种数据源.如何避免BU ...
- Angular快速学习笔记(4) -- Observable与RxJS
介绍RxJS前,先介绍Observable 可观察对象(Observable) 可观察对象支持在应用中的发布者和订阅者之间传递消息. 可观察对象可以发送多个任意类型的值 -- 字面量.消息.事件. 基 ...
- [Angular] Creating an Observable Store with Rx
The API for the store is really simple: /* set(name: string, state: any); select<T>(name: stri ...
- Angular的Observable可观察对象(转)
原文:https://blog.csdn.net/qq_34414916/article/details/85194098 Observable 在开始讲服务之前,我们先来看一下一个新东西——Obse ...
- [Angular 2] Rendering an Observable Date with the Async and Date Pipes
Instead of simply pushing numbers on a timer into the template, now we'll move on to pushing actual ...
- Angular学习笔记—RxJS与Observable(转载)
1. Observable与观察者模式的关系 其实这里讲的Observable就是一种观察者模式,只不过RxJS把Observable结合了迭代模式以及附件了很多的operator,让他变得很强大,也 ...
- [Angular] Pluck value from Observable
export class MailFolderComponent implements OnInit{ title: Observable<string>; messages: Obser ...
随机推荐
- Doctype知识点总结
DOCTYPE是document type (文档类型) 的缩写.<!DOCTYPE >声明位于文档的最前面,处于标签之前,它不是html标签.主要作用是告诉浏览器的解析器使用哪种HTML ...
- Java BigDecimal类型的 加减乘除运算
原文: https://blog.csdn.net/xuwei_net/article/details/81253471 加法:add 减法:subtract 乘法:multiply 除法:divid ...
- xcode10下,Build Phases下没有Embed Frameworks
升级xcode10后发现,Build Phases下,找不到Embed Frameworks了,最后发现在General下,有一项“Embedded Binaries",可以在这里添加Fra ...
- mysql 8.0.X 创建新的数据库、用户并授权
一.创建数据库 mysql> create database jira; Query OK, 0 rows affected (0.09 sec) 二.创建用户 mysql> create ...
- [蓝桥杯]2016蓝桥省赛B组题目及详解
/*——————————————————————————————————————————————————————————— [结果填空题]T1 (分值:3) 题目:煤球数目 有一堆煤球,堆成三角棱锥形 ...
- Spark报错
1. Exception in thread "main" java.lang.OutOfMemoryError: Java heap space at com.mysql.jdb ...
- yarn 在Vue框架中的常用命令
初始化项目 yarn add init 安装vue yarn add vue 安装webpack,webpack-dev-server(是一个小型的Node.js Express服务器) yarn a ...
- MySQL——合并查询结果
利用 UNION 关键字,可以给出多条 SELECT 语句,并将它们的结果组合成一个结果集.合并时,两个表对应的列数和数据类型必须相同.SELECT 语句之间使用 UNION 或 UNIO ...
- Win10开机“提示语音”以及”随机播放音乐”
1.在桌面建立一个.txt文件 2.把一下代码拷贝进去: RandomizeCreateObject("SAPI.SpVoice").Speak"先生,为你播放一首mus ...
- subprocess
在没有subprocess这个模块的时候,我们怎么去跟我们的操作系统做交互的呐?下面我们先说说这三个模块:os.system().os.popen().commands. 1. os.system( ...