angularJS学习小结——$apply方法和$watch方法

原创 2016年05月09日 21:18:16


   引言


   最近在项目中封装控件的时候用到了$watch方法来监听module中的值的变化,当时小编对这个方法不是很了


解,所以在网上找了一些资料来学习一下,下面小编就给大家简单介绍一些angularJS中Scope 提供$apply 方法传播


Model 的变化和$watch方法监听module变化。


   $apply使用情景


  AngularJS 外部的控制器(DOM 事件、外部的回调函数如 jQuery UI 空间等)调用了AngularJS 函数之后,必


须调用$apply。在这种情况下,你需要命令 AngularJS 刷新自已(模型、视图等),$apply就是用来做这件事情


的。我们在使用$apply这个方法的时候,只要可以,请把要执行的代码和函数传递给$apply 去执行,而不要自已执


行那些函数然后再调用$apply。


   下面看一个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.com/libs/angular.js/1.4.6/angular.min.js"></script>

    <script src="http://cdn.bootcss.com/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="李四"这句代码写在s


etTimeout函数中,界面上显示的值根本就不会改变。


   $watch方法监听module变化


  当你的数据模型中某一部分发生变化时,$watch 函数可以向你发出通知。你可以监控单个对象的属性,也可以


监控需要经过计算的结果(函数),实际上只要能够被当作属性访问到,或者可以当作一个JavaScript 函数被计算


出来,就可以被$watch 函数监控。它的函数签名为:

 

 <span style="font-family:SimSun;">  $watch(watchFn, watchAction, deepWatch)</span>

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


  watchAction参数:这是一个函数或者表达式,当watchFn 发生变化时会被调用。如果是函数的形式,它将会接收


到watchFn 的新旧两个值,以及作用域对象的引用。其函数签名为function(newValue, oldValue, scope)。


 deepWatch参数:如果设置为true,这个可选的布尔型参数将会命令Angular 去检查被监控对象的每个属性是否发


生了变化。如果你想要监控数组中的元素,或者对象上的所有属性,而不只是监控一个简单的值,你就可以使用这个


参数。


  下面看一个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.com/libs/angular.js/1.4.6/angular.min.js"></script>

    <script src="http://cdn.bootcss.com/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.cn/code/ovjwuxhn


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

理解Angular中的$apply()以及$digest()

$apply()和$digest()在AngularJS中是两个核心概念,但是有时候它们又让人困惑。而为了了解AngularJS的工作方式,首先需要了解$apply()和$digest()是如何工作的...

(二十) 理解和解决angularJS报错$apply already in progress

如果我们使用了angularJS中的$scope.$apply()或者$scope.$digest(),我们很可能会遇到类似下面的错误,虽然这个错误没有太大影响,但是在日志中看起来还是很不爽的,日志中...

关于angularJS的$watch的 一些小用法

$watch方法,它可以帮助我们在每个scope中监视其中的变量。$watch 单一的变量对于普通的变量时,如数字,字符串等,直接如下写是可以监视到变量的变化,并执行相应的函数的。$scope.cou...

angular中$watch踩的坑

html> html ng-app="myApp"> head> meta charset="UTF-8"> title>angular demotitle> script s...

理解Angular中的$apply()以及$digest()

理解Angular中的apply()以及apply()以及digest() 分类: AngularJS JavaScript 2014-08-20 13:49 13320人阅读 评论(3) 收藏 举...

《AngularJS》----$apply 与 $watch

在AngularJS的一些项目中,我们经常用到$apply 与 $watch ,这两个对象,这另个对象都依赖于$scope对象,其中,$apply应用与传播modle的变化,而$watch是用来监测m...

关于angularjs中,数据模型被改变,页面不刷新的解决办法

刚用angularjs时,确实被它的双向数据绑定震住了,但同时没有完合使用angularjs的方法,从而出现数据模型被改变,但页面不能随之更改,需要$scope.$apply()强制更新数据模型. 实...
  • baby97
  • baby97
  • 2015年12月16日 16:43
  • 30032

AngularJS $watch用法

$watch()执行时会先调用一次传入的回调,可以认为是初始化。 用法: $scope.name = 'zhangsan'; $scope.count=0; $scope.$watch(...

angularJS 中异步赋值 界面中显示 $apply

anglurJS 中异步赋值 界面中显示 $apply 使用

angularjs 高级玩法 创建递归的模板

angularjs,创建递归的模板
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:angularJS学习小结——$apply方法和$watch方法
举报原因:
原因补充:

(最多只允许输入30个字)