首页 > Web开发 > 详细

promise和Rxjs的一点区别

时间:2017-08-20 19:10:35      阅读:1177      评论:0      收藏:0      [点我收藏+]

标签:blog   spa   ++   observe   con   pro   clear   cnblogs   span   

promise 代码 

let promise = new Promise( (resolve) => {
      setTimeout(() => {
          resolve(‘chen‘);
      },2000)
    });
    promise.then((value) => {
      console.log(value);
    })

Rxjs代码

let start = new Observable( (observer) => {
      let timeOut = setTimeout( () => {
        observer.next(‘chen2‘);
      },4000)
      
    })
    let str = start.subscribe( (value) => {
      console.log(value);
    })

 

区别1:  rxjs可以取消subscribe,promise不可以

  setTimeout( () => {
       str.unsubscribe();
   },1000)

 

区别2: rxjs可以发射多次,promise只能发射一次

let setTime2;
    let start2 = new Observable( (observable) => {
      let count = 0;
      setTime2 = setInterval( () => {
        observable.next(count++);
      },1000)
    })
    let str2 = start2.subscribe( (num) => {
        console.log(num);
        if(num > 10){
          str2.unsubscribe();
          clearInterval(setTime2);
        } 
    })

 

区别3: rxjs 自带了许多的工具函数,如filter等

promise和Rxjs的一点区别

标签:blog   spa   ++   observe   con   pro   clear   cnblogs   span   

原文:https://www.cnblogs.com/blogcxz/p/7400797.html

(0)
(0)
   
举报
评论 一句话评论(0
0条  
登录后才能评论!
© 2014 designnerd.net 版权所有 鲁ICP备09046678号-4
打开技术之扣,分享程序人生!
             

鲁公网安备 37021202000002号