这里有新鲜出炉的 AngularJS 教程,程序狗速度看过来!
AngularJS 诞生于 Google 是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入,等等。
这篇文章主要介绍了 AngularJS 中 $apply 方法和 $watch 方法用法, 结合实例形式总结分析了 $apply 方法和 $watch 方法的功能、参数含义、使用技巧与相关注意事项, 需要的朋友可以参考下
本文实例总结了 AngularJS 中 $apply 方法和 $watch 方法用法。分享给大家供大家参考,具体如下:
引言
最近在项目中封装控件的时候用到了 $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="李四" 这句代码写在 setTimeout 函数中,界面上显示的值根本就不会改变。
$watch 方法监听 module 变化
当你的数据模型中某一部分发生变化时,$watch 函数可以向你发出通知。你可以监控单个对象的属性,也可以监控需要经过计算的结果(函数),实际上只要能够被当作属性访问到,或者可以当作一个 JavaScript 函数被计算出来,就可以被 $watch 函数监控。它的函数签名为:
- $watch(watchFn, watchAction, deepWatch)
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
希望本文所述对大家 AngularJS 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0507/329629.html