在 AngularJS 中创建承诺 [英] Create promise in AngularJS

查看:18
本文介绍了在 AngularJS 中创建承诺的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用 $q 服务在 Angular 中创建一个承诺.它返回从 Web 服务检索的对象.如果对象在缓存中,它会在不调用 Web 服务的情况下返回它.

I'm trying to create a promise in Angular with the $q service. It returns an object retrieved from a web service. If the object is in the cache, it returns it without calling the web service.

问题是两个解决方案都被调用了.

The problem is that the two resolves are getting called.

也许,我是否使用了 promise 反模式?

Maybe, Am I using a promise anti-pattern?

这是我的代码:

    function returnMapAsync() {

  return $q(function (resolve, reject) {
    if (navigationMap) {
      resolve(navigationMap);
    } else {
      ServerRequest.getNavigationMap().then(function (data) {
        navigationMap = data.object;
        resolve(navigationMap);
      });
    }
  });
}

谢谢

推荐答案

您不需要将所有内容都包含在 $q() 调用中.为了promisify navigationMap 使用 $q.when:

You shouldn't need to wrap everything in the $q() call. In order to promisify navigationMap use $q.when:

function returnMapAsync() {

    if (navigationMap) {
        return $q.when(navigationMap);
    }
    return ServerRequest.getNavigationMap();
}

这篇关于在 AngularJS 中创建承诺的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆