加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

AngularJS – $watch一个对象

发布时间:2020-12-17 09:34:23 所属栏目:安全 来源:网络整理
导读:我想监视字典中的更改,但由于某些原因没有调用watch回调。 这里是我使用的控制器: function MyController($scope) { $scope.form = { name: 'my name',surname: 'surname' } $scope.$watch('form',function(newVal,oldVal){ console.log('changed'); });}

我想监视字典中的更改,但由于某些原因没有调用watch回调。

这里是我使用的控制器:

function MyController($scope) {
    $scope.form = {
        name: 'my name',surname: 'surname'
    }

    $scope.$watch('form',function(newVal,oldVal){
        console.log('changed');
    });
}

这里是小提琴:http://jsfiddle.net/Y8ByG/

我期望$ watch回调被触发每次名称或姓氏改变,但它不会发生。

什么是正确的方法呢?

调用$ watch,使用true作为第三个参数:

$scope.$watch('form',oldVal){
    console.log('changed');
},true);

默认情况下,当在JavaScript中比较两个复杂对象时,将检查它们是否为“引用”相等,这将询问这两个对象是否引用相同的事物,而不是“值”相等,检查那些属性的值对象是相等的。

按Angular documentation,第三个参数是objectEquality:

When objectEquality == true,inequality of the watchExpression is determined according to the 07001 function. To save the value of the object for later comparison,the 07002 function is used. This therefore means that watching complex objects will have adverse memory and performance implications.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读