Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了AngularJS – 为什么是$apply需要正确解析一个$q promise?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图在我的角应用程序中写一个小服务,这将使我能够选择在全局Javascript对象中指定的配置参数。我不想尝试访问全局配置对象,除非文档准备好了(因为我不能保证脚本元素将被插入到HTML中的顺序)。

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

@H_882_3@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

大佬总结

以上是大佬教程为你收集整理的AngularJS – 为什么是$apply需要正确解析一个$q promise?全部内容,希望文章能够帮你解决AngularJS – 为什么是$apply需要正确解析一个$q promise?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。