angularjs – 将角度1中的promise转换为角度2中的可观察值

前端之家收集整理的这篇文章主要介绍了angularjs – 将角度1中的promise转换为角度2中的可观察值前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我仍在学习角度2中的可观察性,并且无法弄清楚如何将角度1中的代码转换为角度2.

function promiseFunc() {
  var deferred = $q.defer();      

  $http.post(url,something)
    .then(function (response) {
      if (response === 1) deferred.resolve(response.data);
      else deferred.reject();
    }).catch(function (e) {
      deferred.reject(e);
    });

  return deferred.promise;
}

任何人都可以告诉我如何使用角度2可观察转换此代码

编辑:

如果http.post是可选的怎么办?

function promiseFunc(param1) {
  var deferred = $q.defer();      

  if (param1 === 1) {
    deferred.resolve(1);
  } else {
    $http.post(url,something)
      .then(function (response) {
        if (response.x === 1) deferred.resolve(response);
        else deferred.reject();
      }).catch(function (e) {
        deferred.reject(e);
      });
  }

  return deferred.promise;
}

我在observable中缺少的是调用解析和拒绝的能力.可以在可观察的情况下完成吗?

解决方法

someMethod() {
  if(param === 1) {
    return Observable.of(1);
  } else {
    return this.http.post(url,something)
    .map(
      response => {
       let data = response.json();
       if(data === 1) {
         return 1;
       }
       throw 'some error';
      }
    );
  }
}

那就像使用它一样

this.someMethod().subscribe(
  data => console.log(data),error => console.log(error),() => console.log('completed')
);

猜你在找的Angularjs相关文章