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

AngularJS – 为什么是$apply需要正确解析一个$q promise?

发布时间:2020-12-17 08:32:09 所属栏目:安全 来源:网络整理
导读:我试图在我的角应用程序中写一个小服务,这将使我能够选择在全局Javascript对象中指定的配置参数。我不想尝试访问全局配置对象,除非文档准备好了(因为我不能保证脚本元素将被插入到HTML中的顺序)。 然而,我不明白为什么我需要调用$ apply的分辨率实际传播
我试图在我的角应用程序中写一个小服务,这将使我能够选择在全局Javascript对象中指定的配置参数。我不想尝试访问全局配置对象,除非文档准备好了(因为我不能保证脚本元素将被插入到HTML中的顺序)。

然而,我不明白为什么我需要调用$ apply的分辨率实际传播到那个回调。

myModule.service('GlobalConfigService',['$q','$rootScope',function($q,$rootScope) {
    var def = $q.defer();
    $(document).ready(function() {
        def.resolve(MyConfig.val);
        $rootScope.$apply();
    });

    def.promise.then(function () {
        console.log('I am called only when $apply() is called. Why?');
    });

    return def.promise;
}]);
在AngularJS中,resolve()的结果在$ digest周期内不是立即传播,而是异步传播。这意味着,当发生摘要周期时,仅调用()稍后调用与then()注册的回调。

在你的代码中,没有什么会导致Angular进入一个摘要循环,所以从不调用then()回调。调用$ apply()是使摘要周期运行的一种方法。另一种方法:添加一个按钮,ng单击不做任何事情,然后点击它,它将导致一个摘要周期,你应该看到的结果:

<button ng-click="">Force digest by clicking me</button>

参见http://stackoverflow.com/a/14657974/215945

(编辑:李大同)

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

    推荐文章
      热点阅读