最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Rxjs初探

    正文概述 掘金(loveEternity)   2021-02-24   750

    Rxjs是什么

    Rxjs是一个库,通过使用observable序列来编写异步和基于事件的程序,Rxjs的核心类型就是Observable。下面我们先通过一个简单的例子来认识一下Rxjs。

    import {Observable} from 'rxjs'
    const observable = new Observable(subscribe => {
        subscribe.next('Hello');
        subscribe.next('Rxjs');
    });
    observable.subscribe(v => console.log(v));
    
    // 输出结果
    Hello
    Rxjs
    

    下面开始介绍Rxjs的相关API和使用

    Observable(可观察对象)

    Observable是Rxjs核心类型,可以通过Observable来生成可观察对象,然后进行订阅和分发。介绍具体使用之前,先介绍两个概念pull(拉取)push(推送),拉取和推送是两种不同的协议,用来描述数据生产者数据消费者之间是如何通信的。

    • pull(拉取): 比如函数和客户端对服务端发出的http请求,是消费者决定何时去生产者获取数据。
    • push(推送): 比如Promise和socket,是生产者决定何时向消费者推送数据。
    类型生产者消费者
    pull(拉取)被动:当被请求时产生数据主动:决定何时产生数据push(推送)主动:按自己的节奏生产数据被动:对接收的数据作出反应

    而我们今天的主角Observable就是属于push(推送)类型的。

    import {Observable} from 'rxjs';
    const observable = new Observable(subscribe => {
       subscribe.next('value');
    })
    

    通过new关键字实例化Observable生成可观察对象Observable的实例,在实例化时传入一个回调函数,里面通过next调用(还可以调用errorcomplete)来通知订阅者或者说是数据消费者来执行,下面就是消费者的订阅:

    observable.subscribe(v => console.log(v))
    

    通过subscribe来进行订阅,里面的回调函数就是数据消费者,每次订阅就会执行实例化时的回调函数,回调函数里每执行一次next,就会执行一次数据消费者,并将参数传递给数据消费者。subscribe订阅参数有两种类型:

    • 函数: 内部会被赋值给next属性
    • 对象:
      • next: 实例化observable时,函数参数里调用next时,就会执行该属性值
      • error: 实例化observable时,函数参数里调用error时,就会执行该属性值

    上面提到实例化回调函数里可以执行除next之外还可以执行error和complete,其中执行error就会执行订阅者的error属性值,而执行complete就代表执行完成了,下面如果有next或者error的执行也不会通知到订阅者。

    订阅函数subscribe返回一个订阅者对象,我们可以通过执行订阅者对象的unsubscribe方法来取消订阅:

    const sub = observable.subscribe(v => console.log(v));
    // 取消订阅
    sub.unsubscribe();
    

    同时还可以通过返回的订阅者对象的add方法把其他订阅添加到一个订阅中,一起进行取消,例如:

    const sub1 = observable.subscribe(v => console.log(`sub1 ${v}`));
    const sub2 = observable.subscribe(v => console.log(`sub2 ${v}`));
    // 将sub2的订阅添加到sub1中
    sub1.add(sub2);
    setTimeout(() => {
    	// 此时订阅sub1和sub2都会被取消订阅
    	sub1.unsubscribe();
    }, 2000);
    

    Subject

    上面介绍的observable是单播的,也就是我们订阅时,只会通知到订阅的这个,如下:

    import {Observable} from 'rxjs';
    const observable = new Observable(subscribe => {
    	subscribe.next('111');
        subscribe.next('222');
    })
    
    observable.subscribe(v => console.log(`observable1 ${v}`));
    observable.subscribe(v => console.log(`observable2 ${v}`));
    

    输出结果是:

    observable1 111
    observable1 222
    observable2 111
    observable2 222
    

    如果是多播的话会输出:

    observable1 111
    observable2 111
    observable1 222
    observable2 222
    

    Subject是特殊的Observable类型,它允许将值多播到多个Observer。在Subject内部,subscribe不调用传递值的新执行,它是将观察者注册到注册列表中。类似于addEventListener工作方式,使用方式如下:

    import {Subject} from 'rxjs';
    
    const subject = new Subject();
    subject.subscribe(val => console.log(`subject1 ${val}`));
    subject.subscribe(val => console.log(`subject2 ${val}`));
    subject.next(1);
    subject.next(2);
    

    输出结果:

    subject1 1
    subject2 1
    subject1 2
    subject2 2
    

    由于主题是观察者即具有next、error等属性,可以像如下使用

    import {Subject, from } from 'Rxjs';
    
    const subject = new Subject();
    subject.subscribe(v => console.log(v));
    const observable = from([1,2,3]);
    observable.subscribe(subject);
    

    输出结果:

    1
    2
    3
    

    至此Rxjs基本的API和使用方法介绍完毕了。在实际工作中,会在Angular中进行使用,由于我本身是Vue技术栈,最近才开始接触Angular,发现RxjsAngular中使用还是很频繁的,就大致学习了一下。 【好好学习,天天向上?】


    下载网 » Rxjs初探

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元