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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |