angular之$watch方法详解
2018-06-24 00:21:48来源:未知 阅读 ()
在$apply方法中提到过脏检查,首先apply方法会触发evel方法,当evel方法解析成功后,会去触发digest方法,digest方法会触发watch方法。
(1)$watch简介
在digest执行时,如果watch观察的的value与上一次执行时不一样时,就会被触发。
AngularJS内部的watch实现了页面随model的及时更新。
$watch方法在用的时候主要是手动的监听一个对象,但对象发生变化时触发某个事件。
(2)watch方法用法
$watch(watchFn,watchAction,deepWatch)
watchFn:angular表达式或函数的字符串
watchAction(newValue,oldValue,scope):watchFn发生变化会被调用
deepWatch:可选的布尔值命令检查被监控的对象的每个属性是否发生变化
$watch会返回一个函数,想要注销这个watch可以使用函数
(3)例子
在前面的例子中,当name的表单改变30次,然后触发某个事件。
控制器代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
var firstController = function ($scope){ $scope.name= '张三' ; $scope.count=0; // 监听一个model 当一个model每次改变时 都会触发第2个函数 $scope.$watch( 'name' , function (newValue,oldValue){ ++$scope.count; if ($scope.count > 30){ $scope.name = '已经大于30次了' ; } }); } |
html代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<!DOCTYPE html> < html > < head > < meta charset = "utf-8" > </ head > < body > < div ng-app = "" > < div ng-controller = "firstController" > < input type = "text" value = "" ng-model = "name" /> 改变次数:{{count}}-{{name}} </ div > </ div > < script type = "text/javascript" src = "app/index.js" ></ script > < script type = "text/javascript" src = "../../vendor/angular/angularjs.js" ></ script > </ body > </ html > |
运行效果如下:
前30次可以随意修改:
当修改了30次后,name固定为'已经大于30次了':
这就是watch的作用,model每一次改变时都会触发第二个函数。
(4)watch的第三个参数
当监听的为一个对象或者数组时,例如:
1
2
3
4
|
$scope.data = { name : '李四' , count:20 } |
此时data里的name和count都要监听,那么可以这么写:
1
2
3
|
$scope.$watch( 'data' , function (){ }, true ) |
如果不加第三个参数,那么只会监听data,只有当data引用改变时才会触发。
因此当需要监听一些引用对象需要把第三个参数设置成true。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- js实现翻页后保持checkbox选中状态的实现方法 2020-03-25
- NiftyCube实现圆角边框的方法 2020-03-20
- 根据分辨率调用css文件的方法 2020-03-19
- JS简单去除数组中重复项的方法 2020-03-16
- javascript 中关于array的常用方法详解 2020-03-16
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash