寻仙手游官网-AngularJS中$apply方法和$watch方法用法总结
函数
石景数学网
函数
2021-09-10

本文实例总结了AngularJS中$apply方法和$watch方法用法。分享给大家供大家参考,具体如下:

最近在项目中封装控件的时候用到了$watch方法来监听module中的值的变化,当时小编对这个方法不是很了解,所以在网上找了一些资料来学习一下,下面小编就给大家简单介绍一些AngularJS中Scope 提供$apply 方法传播Model 的变化和$watch方法监听module变化。

AngularJS 外部的控制器(DOM 事件、外部的回调寻仙手游官网如 jQuery UI 空间等)调用了AngularJS 寻仙手游官网之后,必须调用$apply。在这种情况下,你需要命令 AngularJS 刷新自已(模型、视图等),$apply就是用来做这件事情的。我们在使用$apply这个方法的时候,只要可以,请把要执行的代码和寻仙手游官网传递给$apply 去执行,而不要自已执行那些寻仙手游官网然后再调用$apply。

下面看一个Demo,写一个定时器在两秒以后改变name的值:

RunJS {{name}} {{**e}} var app = angular.module("myApp",[]); app.controller('firstController',function($scope,$timeout){ setTimeout(function(){ $scope.$apply(function(){ $scope.name="李四"; }) },2000); $scope.name="张三"; $scope.**e='10'; $scope.show=function(){ $scope.name='点击后的name'; } $timeout(function(){ $scope.**e='50'; },2000); })

在上面代码中如果我们不使用$apply来传播name值的改变,而是直接将$scope.name="李四"这句代码写在setTimeout寻仙手游官网中,界面上显示的值根本就不会改变。

当你的数据模型中某一部分发生变化时,$watch 寻仙手游官网可以向你发出通知。你可以寻仙手游官网单个对象的属性,也可以寻仙手游官网需要经过计算的结果(寻仙手游官网),实际上只要能够被当作属性访问到,或者可以当作一个JavaScript 寻仙手游官网被计算出来,就可以被$watch 寻仙手游官网寻仙手游官网。它的寻仙手游官网签名为:

$watch(watchFn, watchAction, deepWatch)

watchFn参数:这个是我们监听地方目标对象,它是一个带有angular表达式或者寻仙手游官网的字符串;

watchAction参数:这是一个寻仙手游官网或者表达式,当watchFn 发生变化时会被调用。如果是寻仙手游官网的形式,它将会接收到watchFn 的新旧两个值,以及作用域对象的引用。其寻仙手游官网签名为function(newValue, oldValue, scope)。

deepWatch参数:如果设置为true,这个可选的布尔型参数将会命令Angular 去检查被寻仙手游官网对象的每个属性是否发生了变化。如果你想要寻仙手游官网数组中的元素,或者对象上的所有属性,而不只是寻仙手游官网一个简单的值,你就可以使用这个参数。

下面看一个Demo,当费用超过100的时候,运费为0否则运费为10:

RunJS

价格:

个数:

费用: {{sum() | currency:'¥'}}

运费: {{iphone.fre | currency:'¥'}}

总额: {{sum() + iphone.fre | currency:'¥'}}

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 }) })

$watch这个寻仙手游官网在项目中会经常用到,所以我们需要对这个寻仙手游官网灵活的掌握,这样我们在自定控件或者完成一些比较复杂的需求的时候很更加的方便。

以上是小编对中两个方法的总结,这些都是比较入门的知识,如果想更好的对这些知识了解还需要我们在项目中好好的研究。

源码地址:http://runjs.cn/code/ovjwuxhn