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

前端之家收集整理的这篇文章主要介绍了AngularJS – 为什么是$apply需要正确解析一个$q promise?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图在我的角应用程序中写一个小服务,这将使我能够选择在全局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

原文链接:https://www.f2er.com/angularjs/145439.html

猜你在找的Angularjs相关文章