31

我正在尝试在我的 Angular 应用程序中编写一个小服务,这将使我能够选择在全局 Javascript 对象中指定的配置参数。除非文档准备好,否则我不想尝试访问全局配置对象(因为我无法保证将脚本元素插入 HTML 的顺序)。

但是,我不明白为什么我需要调用以$apply使分辨率实际传播到then回调。

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;
}]);
4

1 回答 1

33

在 AngularJS 中,resolve() 的结果是在 $digest 循环内异步传播的,而不是立即传播。这意味着使用 then() 注册的回调将仅在发生摘要循环时(稍后)被调用。

在您的代码中,没有什么会导致 Angular 进入摘要循环,因此永远不会调用 then() 回调。调用 $apply() 是导致摘要循环运行的一种方法。另一种方法:使用 ng-click 添加一个不执行任何操作的按钮,然后单击该按钮,它将导致摘要循环,您应该会看到结果:

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

另请参阅https://stackoverflow.com/a/14657974/215945

于 2013-02-07T22:18:09.657 回答