当前位置:  开发笔记 > 前端 > 正文

Angular 2 Promises还是RxJs?

如何解决《Angular2Promises还是RxJs?》经验,为你挑选了1个好方法。

看看RxJs,它们似乎更强大,但到目前为止我们一直在使用Promise在角度应用程序中执行Ajax.

在Angular 2应用程序中哪一个是首选方法?在使用RxJs时,我们是否需要包含ES6 promise polyfill?



1> Martin Seele..:

它们可以一起使用,效果非常好.RxJS不仅用于解析promise,还用于异步应用程序流.在解析promise时,可以使用Rx.Observable.fromPromise创建一个发出一个元素的Observable.

这是一个例子:

// Create a promise which resolves 42
var promise1 = new RSVP.Promise(function (resolve, reject) {
    resolve(42);
});

var source1 = Rx.Observable.fromPromise(promise1);

var subscription1 = source1.subscribe(
  function (x) {
    console.log('Next: %s', x);
  },
  function (err) {
    console.log('Error: %s', err);
  },
  function () {
    console.log('Completed');
  });

// => Next: 42
// => Completed

// Create a promise which rejects with an error
var promise2 = new RSVP.Promise(function (resolve, reject) {
    reject(new Error('reason'));
});

var source2 = Rx.Observable.fromPromise(promise2);

var subscription2 = source2.subscribe(
  function (x) {
    console.log('Next: %s', x);
  },
  function (err) {
    console.log('Error: %s', err);
  },
  function () {
    console.log('Completed');
  });

// => Error: Error: reject

对于使用RxJS的角度2演示,请查看angular2-rxjs-chat

推荐阅读
雯颜哥_135
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有