AngularJS 为什么 我在controller里修改了 变量的值,dom 没有改变

'use strict'
app.controller('xxxxx', function($scope) {
    $scope.aaaa =null;
    
    $scope.chooseImage = function(){
        wx.chooseImage({
            sourceType: [],
                success:function(res){
                    $scope.aaaa =1
                }
            });
        };
});
<p ng-click="chooseImage()">{{aaaa}}</p>

点击后页面aaaa的值并不会 改变为 1

因为 wx.chooseImage 这个方法是微信的API, 并不在angular context里面,没有调用apply方法。

$apply方法使用情景:AngularJS 外部的控制器(DOM 事件、外部的回调函数如 jQuery UI 空间等)调用了 AngularJS 函数之后,必须调用$apply。在这种情况下,你需要命令 AngularJS 刷新自已(模型、视图等) ,$apply 就是用来做这件事情的。

之前看见同事写个$timeout(function(){}) 就好了,也是好奇。原来angular在$timeout方法里已经封装了apply方法。

 

我主要看了这两篇文章:

谈谈Angular关于$watch,$apply 以及 $digest的工作原理

《AngularJS》----$apply 与 $watch

posted @ 2017-12-07 17:48  wupanpan  阅读(1150)  评论(0编辑  收藏  举报