gpt4 book ai didi

javascript - angularJS 为什么 $scope.$watch 不能工作?

转载 作者:行者123 更新时间:2023-12-02 16:08:31 25 4
gpt4 key购买 nike

我想添加一个$watch来监视$scope.data是否更改,但它不起作用

[http://jsbin.com/biqesojaqu/1/edit?html,js,console,output][1]

app.html

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.26/angular.min.js"></script>
<meta charset="utf-8">
<title>JS Bin</title>
</head>
<body ng-app="App" ng-controller="TestController">
<div>
<ul>
<li ng-repeat="item in data"> {{ item.name }}--{{ item.status }}</li>
<button ng-click="addOnePerson()">ADD</button>
</ul>
</div>
</body>
</html>

app.js

var App = angular.module("App", []);

App.controller('TestController', function ($scope) {
$scope.data = [
{name: 'cc', status: true},
{name: 'bob', status: false}
];
$scope.name = 'nataila';
$scope.addOnePerson = function () {
var personCount = $scope.data.length;
personCount += 1;
$scope.data.unshift({name: 'cc'+personCount, status: true});
};
$scope.$watch('data', function (){
console.log('has changed');
});
});

当我点击按钮时,我认为控制台会输出has henged,但什么也没有请告诉我为什么,在 JSbin 中帮助我很好

最佳答案

使用$watchCollection作为数组对象

$scope.$watchCollection('data', function (){
console.log('has changed');
});

JSBin

关于javascript - angularJS 为什么 $scope.$watch 不能工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30476184/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com