AngularJS中$apply方法和$watch方法用法总结
本文实例了AngularJS中$apply方法和$watch方法用法。分享给大家供大家参考,具体如下
引言
最近在项目中封装控件的时候用到了$watch方法来监听module中的值的变化,当时长沙网络推广对这个方法不是很了解,所以在网上找了一些资料来学习一下,狼蚁网站SEO优化长沙网络推广就给大家简单介绍一些AngularJS中Scope 提供$apply 方法传播Model 的变化和$watch方法监听module变化。
$apply使用情景
AngularJS 外部的控制器(DOM 事件、外部的回调函数如 jQuery UI 空间等)调用了AngularJS 函数之后,必须调用$apply。在这种情况下,你需要命令 AngularJS 刷新自已(模型、视图等),$apply就是用来做这件事情的。我们在使用$apply这个方法的时候,只要可以,请把要执行的代码和函数传递给$apply 去执行,而不要自已执行那些函数然后再调用$apply。
狼蚁网站SEO优化看一个Demo,写一个定时器在两秒以后改变name的值
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>RunJS</title> <script src="http://apps.bdimg./libs/angular.js/1.4.6/angular.min.js"></script> <script src="http://cdn.bootcss./angular.js/1.2.9/angular-route.min.js"></script> <script src="serviceJS01.js"></script> </head> <body ng-app="myApp" > <div ng-controller="firstController" ng-click="show()"> {{name}} {{age}} </div> </body> </html> <script> var app = angular.module("myApp",[]); app.controller('firstController',function($scope,$timeout){ setTimeout(function(){ $scope.$apply(function(){ $scope.name="李四"; }) },2000); $scope.name="张三"; $scope.age='10'; $scope.show=function(){ $scope.name='点击后的name'; } $timeout(function(){ $scope.age='50'; },2000); }) </script>
在上面代码中如果我们不使用$apply来传播name值的改变,而是直接将$scope.name="李四"这句代码写在setTimeout函数中,界面上显示的值根本就不会改变。
$watch方法监听module变化
当你的数据模型中某一部分发生变化时,$watch 函数可以向你发出通知。你可以监控单个对象的属性,也可以监控需要经过计算的结果(函数),实际上只要能够被当作属性访问到,或者可以当作一个JavaScript 函数被计算出来,就可以被$watch 函数监控。它的函数签名为:
$watch(watchFn, watchAction, deepWatch)
watchFn参数这个是我们监听地方目标对象,它是一个带有angular表达式或者函数的字符串;
watchAction参数这是一个函数或者表达式,当watchFn 发生变化时会被调用。如果是函数的形式,它将会接收到watchFn 的新旧两个值,以及作用域对象的引用。其函数签名为function(newValue, oldValue, scope)。
deepWatch参数如果设置为true,这个可选的布尔型参数将会命令Angular 去检查被监控对象的每个属性是否发生了变化。如果你想要监控数组中的元素,或者对象上的所有属性,而不只是监控一个简单的值,你就可以使用这个参数。
狼蚁网站SEO优化看一个Demo,当费用超过100的时候,运费为0否则运费为10
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>RunJS</title> <script src="http://apps.bdimg./libs/angular.js/1.4.6/angular.min.js"></script> <script src="http://cdn.bootcss./angular.js/1.2.9/angular-route.min.js"></script> <script src="serviceJS01.js"></script> </head> <body ng-app="myApp" > <div ng-controller="firstController" ng-click="show()"> <p>价格<input type="text" ng-model="iphone.money"></p> <p>个数<input type="text" ng-model="iphone.num"></p> <p>费用 <span>{{sum() | currency:'¥'}}</span></p> <p>运费 <span>{{iphone.fre | currency:'¥'}}</span></p> <p>总额 <span>{{sum() + iphone.fre | currency:'¥'}}</span></p> </div> </body> </html> <script> var app = angular.module("myApp",[]); app.controller('firstController',function($scope){ $scope.iphone={ money:5, num:1, fre:10 }; $scope.sum=function(){ return $scope.iphone.money $scope.iphone.num; } $scope.$watch($scope.sum,function(newValue,oldValue){ $scope.iphone.fre=newValue>=100?0:10 }) }) </script>
$watch这个函数在项目中会经常用到,所以我们需要对这个函数灵活的掌握,这样我们在自定控件或者完成一些比较复杂的需求的时候很更加的方便。
小结
以上是长沙网络推广对中两个方法的,这些都是比较入门的知识,如果想更好的对这些知识了解还需要我们在项目中好好的研究。
源码地址http://runjs./code/ovjwuxhn
更多关于AngularJS相关内容感兴趣的读者可查看本站专题《》及《》
希望本文所述对大家AngularJS程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程