$watch(Collection)不能捕捉对象属性的变化
$watch(Collection) doesn't catch object property changes
我在模板中有这些字符串:
<li class="list__item" ng-repeat="item in items">
<input class="toggle" type="checkbox" ng-model="item.done">
<label>{{ item.description }}</label>
<button class="destroy" ng-click="remove(item)"></button>
</li>
和js代码在我的控制器:
$scope.$watchCollection('items', function(newValue, oldValue) {
cache.set($scope.items);
});
美元范围。项被定义
当我检查一个项目时,$watchCollection没有捕捉到这个变化。我阅读了todo mvc源代码,没有发现我的错误。
错误在哪里?谢谢。
watchCollection
观察items
集合的浅变化。这意味着只有当元素被添加/删除到items
集合时,它才会触发。如果你想让手表在你改变item
的属性时开火,你必须使用watch
。
From the docs:
Shallow监视对象的属性,并在任何属性发生变化时触发(对于数组,这意味着监视数组项;对于对象映射,这意味着要监视属性)。
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性