加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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

发布时间:2020-12-17 17:17:31 所属栏目:安全 来源:网络整理
导读:我仍在学习角度2中的可观察性,并且无法弄清楚如何将角度1中的代码转换为角度2. function promiseFunc() { var deferred = $q.defer(); $http.post(url,something) .then(function (response) { if (response === 1) deferred.resolve(response.data); else d
我仍在学习角度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')
);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读