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的更多相关文章

  1. [Angular] Observable.catch error handling in Angular

    import { Observable } from 'rxjs/Observable'; import 'rxjs/add/operator/map'; import 'rxjs/add/opera ...

  2. [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 ...

  3. Angular基础(八) Observable & RxJS

    对于一个应用来说,获取数据的方法可以有很多,比如:Ajax, Websockets, LocalStorage, Indexdb, Service Workers,但是如何整合多种数据源.如何避免BU ...

  4. Angular快速学习笔记(4) -- Observable与RxJS

    介绍RxJS前,先介绍Observable 可观察对象(Observable) 可观察对象支持在应用中的发布者和订阅者之间传递消息. 可观察对象可以发送多个任意类型的值 -- 字面量.消息.事件. 基 ...

  5. [Angular] Creating an Observable Store with Rx

    The API for the store is really simple: /* set(name: string, state: any); select<T>(name: stri ...

  6. Angular的Observable可观察对象(转)

    原文:https://blog.csdn.net/qq_34414916/article/details/85194098 Observable 在开始讲服务之前,我们先来看一下一个新东西——Obse ...

  7. [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 ...

  8. Angular学习笔记—RxJS与Observable(转载)

    1. Observable与观察者模式的关系 其实这里讲的Observable就是一种观察者模式,只不过RxJS把Observable结合了迭代模式以及附件了很多的operator,让他变得很强大,也 ...

  9. [Angular] Pluck value from Observable

    export class MailFolderComponent implements OnInit{ title: Observable<string>; messages: Obser ...

随机推荐

  1. 2018-2019-2 20175217 实验二《Java面向对象程序设计》实验报告

    一.实验报告封面 课程:Java程序设计 班级:1752班 姓名:吴一凡 学号:20175217 指导教师:娄嘉鹏 实验日期:2019年4月15日 实验时间:--- 实验序号:实验二 实验名称:Jav ...

  2. FLIR 相机采集程序

    https://www.ptgrey.com/Downloads/GetSecureDownloadItem/11048 Grasshopper3 4.1 MP Mono USB3 Vision (C ...

  3. eplan图框制作

    1. 首先,新建一个原理图项目 2. 新建图框.选择“工具”→“主数据”→“图框”→“新建” 在“文件名”中输入文件名,保存. 3.添加新建图框属性选项.选中“新建符号*”,添加选项 4. 设置图框的 ...

  4. 团队开发项目--NABCD模型

    N(need)需求: 鉴于在学校中的大部分爱学习的学生平时都去拍空教室的占有情况,我们发现有的时候太多,导致同学们们拍照会浪费很长的时间,而且空教室的显示不是一下子全出来,有的时候还会出现无法显示的情 ...

  5. JS获取登录者IP和登录城市

    登录城市:<sp class="cy"></sp><br /> 管理员个数:<font color=</strong>< ...

  6. Python链表的实现与使用(单向链表与双向链表)

    参考[易百教程]用Python实现链表及其功能 """ python链表的基本操作:节点.链表.增删改查 """ import sys cl ...

  7. 什么是CAS机制?(转)

    围绕下面四个点展开叙述: 一:什么是CAS机制? 二:Java当中CAS的底层实现 三:CAS的ABA问题和解决方法 四:java8对CAS的优化 一:什么是CAS机制? 我们先看一段代码: 启动两个 ...

  8. Windows Server 2008 R2提示api-ms-win-crt-runtime-l1-1-0.dll 丢失解决方法

    在一台服务器的全新windows Server 2008 R2 服务器上配置php运行环境, 在启动Apache之后,显示下图错误: 解决方法: 1.安装VC redit.exe程序解决 是VC的一个 ...

  9. pycharm中查找一个对象在哪里被引用

    pycharm中查找一个对象在哪里被引用 2018年10月28日 19:22:20 vivian_wanjin 阅读数:1600   PyCharm的Find Usages功能可以查找某个对象(变量. ...

  10. 安装php的lavavel框架的流程(亲测)

    windows上安装配置laravel 初次接触laravel会觉得它的安装方式比较不一样,与Linux上安装软件的方式很相似. 学习laravel的最好方式当然是看官方文档,笔者就在这里讲官方文档上 ...