• 1,原型:$watch: function(watchExp, listener, objectEquality, prettyPrintExpression){};
  • 2,参数:watchExp(必须):{(function()|string)},可以字符串表达式,也可以带当前scope为参数的函数
  •     - `string`: Evaluated as {@link guide/expression expression}
  •     - `function(scope)`: called with current `scope` as a parameter.
  • 3,参数:listener(必须):function(newVal, oldVal, scope),观察的表达式变化的时候调用的函数。
  • 4,参数:objectEquality(非必须):是否监视个对象,默认为false
  • 5,$scope.$digest().会执行所有的同$scope下的$watch。
  •     但会出错$apply already in progress,换了$rootScope也一样。
  •     原因-参考大牛博客:http://blog.csdn.net/aitangyong/article/details/48972643
  •     $digest、$apply、$$phase这些属性或者方法其实都是$scope中的私有的,最好不要使用。
  • 6,$watch一个对象。
  •     如果要监视对象的变化(地址改变),$watch对象名,第三个参数默认;
  •     如果监测对象中某一属性,可以写user.name的形式,第三个参数默认;
  •     如果监测对象中全部属性,$watch对象名,第三个参数true;
  • 7,$watchGroup,第一个参数是一个表达式的数组或者返回表达式的数组的函数。
  • 8,$watchCollection;
  •     js中数组也是对象,但按照$watch一个对象的方式,只有数组引用变了才能监听变化,增加删除$watch监听不到,所以就有了$watchCollection。
  •      function(obj, listener):第一个参数必须对象或者返回对象的函数。
  • 9,注销$watch
  •          $watch函数返回一个注销监听的函数,太多的$watch将会导致性能问题,$watch如果不再使用,我们最好将其释放掉。

一、使用方法

html

  <div ng-controller="ctrl">
<h2>$watch</h2>
<div>
<input type="text" ng-model="value1"/>
</div>
<div ng-bind="w1"></div> <h2>$watchGroup</h2>
<div>
<input type="text" ng-model="value2"/>
<input type="text" ng-model="value3"/>
</div>
<div ng-bind="w2"></div> <h2>$watchCollection</h2>
<ul>
<li ng-repeat="v in arr" ng-bind="v"></li>
</ul>
<div ng-bind="w3"></div>
</div>

js

    angular.module('nickApp', [])

                .controller("ctrl", ["$scope", "$timeout", function ($scope, $timeout) {
// $watch
var watcher = $scope.$watch("value1", function (newVal, oldVal) {
$scope.w1 = "$watch--" + "new:" + newVal + ";" + "old:" + oldVal;
if (newVal == 'clear') {//设置一个注销监听的条件
watcher(); //注销监听
}
}); // $watchGroup
$scope.$watchGroup(["value2", "value3"], function (newVal, oldVal) {
//注意:newVal与oldVal都返回的是一个数组
$scope.w2 = "$watchGroup--" + "new:" + newVal + ";" + "old:" + oldVal; }); // $watchCollection
$scope.arr = ['nick', 'ljy', 'ljj', 'zhw'];
$scope.$watchCollection('arr', function (newVal, oldVal) {
$scope.w3 = "$watchCollection--" + "new:" + newVal + ";" + "old:" + oldVal; }); $timeout(function () {
$scope.arr = ['my', 'name', 'is', 'nick'];
}, 2000); }])

二、小案例

html

<h2>小案例</h2>
<ul>
<li ng-repeat="item in items.goodsArr">
<p ng-bind="item.goods"></p>
<p>
<span>单价:</span>
<span ng-bind="item.price"></span>
</p>
<div>
<input type="number" ng-model="item.num">
<span>个</span>
</div>
</li>
</ul>
<div>
<span>总计:</span>
<span ng-bind="items.sum"></span>
<span>元</span>
</div>

js

                //         小案例
.factory('watchService', [function () {
var items = {
goodsArr: [{
goods: 'goods1',
price: 10,
num: ''
}, {
goods: 'goods2',
price: 20,
num: ''
}],
sum: 0
};
return {
getItemsSave: function () {
return items;
}
};
}]) .controller('bodyCtl', ['$scope', 'watchService', function ($scope, watchService) {
$scope.items = watchService.getItemsSave(); // 这里要监听数量变化计算综合
//一 只监听所有num变化计算总额
var watchArr = [];
$scope.items.goodsArr.forEach(function (v, i) {
watchArr.push("items.goodsArr[" + i + "]['num']");
}); $scope.$watchGroup(watchArr, function (newVal, oldVal) { //注意:newVal与oldVal都返回的是一个数组
$scope.items.sum = 0;
$scope.items.goodsArr.forEach(function (v, i) {
$scope.items.sum += v.price * (v.num > 0 ? v.num : 0);
});
});
/*
//二 这样写则监听items.goodsArr所有成员
$scope.$watch('items.goodsArr', function () {
$scope.items.sum = 0;
$scope.items.goodsArr.forEach(function (v, i) {
$scope.items.sum += v.price * (v.num > 0 ? v.num : 0);
});
}, true);*/ }])

全部代码

<!DOCTYPE html>
<html ng-app="nickApp">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title>angular之$watch、$watchGroup、$watchCollection</title>
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
<script>
/*
* 1,原型:$watch: function(watchExp, listener, objectEquality, prettyPrintExpression){};
* 2,参数:watchExp(必须):{(function()|string)},可以字符串表达式,也可以带当前scope为参数的函数
* - `string`: Evaluated as {@link guide/expression expression}
* - `function(scope)`: called with current `scope` as a parameter.
* 3,参数:listener(必须):function(newVal, oldVal, scope),观察的表达式变化的时候调用的函数。
* 4,参数:objectEquality(非必须):是否监视个对象,默认为false
* 5,$scope.$digest().会执行所有的同$scope下的$watch。
* 但会出错$apply already in progress,换了$rootScope也一样。
* 原因-参考大牛博客:http://blog.csdn.net/aitangyong/article/details/48972643
* $digest、$apply、$$phase这些属性或者方法其实都是$scope中的私有的,最好不要使用。
* 6,$watch一个对象。
* 如果要监视对象的变化(地址改变),$watch对象名,第三个参数默认;
* 如果监测对象中某一属性,可以写user.name的形式,第三个参数默认;
* 如果监测对象中全部属性,$watch对象名,第三个参数true;
* 7,$watchGroup,第一个参数是一个表达式的数组或者返回表达式的数组的函数。
* 8,$watchCollection;
* js中数组也是对象,但按照$watch一个对象的方式,只有数组引用变了才能监听变化,增加删除$watch监听不到,所以就有了$watchCollection。
* function(obj, listener):第一个参数必须对象或者返回对象的函数。
*/
angular.module('nickApp', []) .controller("ctrl", ["$scope", "$timeout", function ($scope, $timeout) {
// $watch
var watcher = $scope.$watch("value1", function (newVal, oldVal) {
$scope.w1 = "$watch--" + "new:" + newVal + ";" + "old:" + oldVal;
/*
*注销$watch
*太多的$watch将会导致性能问题,$watch如果不再使用,我们最好将其释放掉。
*$watch函数返回一个注销监听的函数,如果我们想监控一个属性,然后在稍后注销它,可以使用下面的方式:
*/
if (newVal == 'clear') {//设置一个注销监听的条件
watcher(); //注销监听
}
}); // $watchGroup
$scope.$watchGroup(["value2", "value3"], function (newVal, oldVal) {
//注意:newVal与oldVal都返回的是一个数组
$scope.w2 = "$watchGroup--" + "new:" + newVal + ";" + "old:" + oldVal; }); // $watchCollection
$scope.arr = ['nick', 'ljy', 'ljj', 'zhw'];
$scope.$watchCollection('arr', function (newVal, oldVal) {
$scope.w3 = "$watchCollection--" + "new:" + newVal + ";" + "old:" + oldVal; }); $timeout(function () {
$scope.arr = ['my', 'name', 'is', 'nick'];
}, 2000); }]) // 小案例
.factory('watchService', [function () {
var items = {
goodsArr: [{
goods: 'goods1',
price: 10,
num: ''
}, {
goods: 'goods2',
price: 20,
num: ''
}],
sum: 0
};
return {
getItemsSave: function () {
return items;
}
};
}]) .controller('bodyCtl', ['$scope', 'watchService', function ($scope, watchService) {
$scope.items = watchService.getItemsSave(); // 这里要监听数量变化计算综合
//一 只监听所有num变化计算总额
var watchArr = [];
$scope.items.goodsArr.forEach(function (v, i) {
watchArr.push("items.goodsArr[" + i + "]['num']");
}); $scope.$watchGroup(watchArr, function (newVal, oldVal) { //注意:newVal与oldVal都返回的是一个数组
$scope.items.sum = 0;
$scope.items.goodsArr.forEach(function (v, i) {
$scope.items.sum += v.price * (v.num > 0 ? v.num : 0);
});
});
/*
//二 这样写则监听items.goodsArr所有成员
$scope.$watch('items.goodsArr', function () {
$scope.items.sum = 0;
$scope.items.goodsArr.forEach(function (v, i) {
$scope.items.sum += v.price * (v.num > 0 ? v.num : 0);
});
}, true);*/ }]) </script>
</head>
<body ng-controller="bodyCtl">
<div ng-view>
<div ng-controller="ctrl">
<h2>$watch</h2>
<div>
<input type="text" ng-model="value1"/>
</div>
<div ng-bind="w1"></div> <h2>$watchGroup</h2>
<div>
<input type="text" ng-model="value2"/>
<input type="text" ng-model="value3"/>
</div>
<div ng-bind="w2"></div> <h2>$watchCollection</h2>
<ul>
<li ng-repeat="v in arr" ng-bind="v"></li>
</ul>
<div ng-bind="w3"></div>
</div> <h2>小案例</h2>
<ul>
<li ng-repeat="item in items.goodsArr">
<p ng-bind="item.goods"></p>
<p>
<span>单价:</span>
<span ng-bind="item.price"></span>
</p>
<div>
<input type="number" ng-model="item.num">
<span>个</span>
</div>
</li>
</ul>
<div>
<span>总计:</span>
<span ng-bind="items.sum"></span>
<span>元</span>
</div>
</div>
</body>
</html>

angular之$watch、$watchGroup、$watchCollection的更多相关文章

  1. Angularjs1.X进阶笔记(1)—两种不同的双向数据绑定

    一. html与Controller中的双向数据绑定 html-Controller的双向数据绑定,在开发中非常常见,也是Angularjs1.x的宣传点之一,使用中并没有太多问题. 1.1数据从ht ...

  2. angular1的复选框指令--checklistModel

    这个指令可以改变一组checkbox的model格式,提交的时候格式为[x,y,z,...] //复选框指令 .directive('checklistModel', ['$parse', '$com ...

  3. $watch, $watchCollection, $watchGroup的使用

    官方文档 $watch简单使用 $watch是一个scope函数,用于监听模型变化,当你的模型部分发生变化时它会通知你. $watch(watchExpression, listener, objec ...

  4. angular之$watch() $watchGroup()和$watchCollection()

    $watch $watch主要是用来监听一个对象,在对象发生变化时触发某个事件. 用法: $scope.$watch(watchFn,watchAction, deepWatch) 接下来讲一下这几个 ...

  5. Angular.js中使用$watch监听模型变化

    $watch简单使用 $watch是一个scope函数,用于监听模型变化,当你的模型部分发生变化时它会通知你. $watch(watchExpression, listener, objectEqua ...

  6. angular源码分析:$compile服务——指令的编写

    这一期中,我不会分析源码,只是翻译一下"https://docs.angularjs.org/api/ng/service/$compile",当然不是逐字逐句翻译,讲解指令应该如 ...

  7. angular源码分析:angular中$rootscope的实现——scope的一生

    在angular中,$scope是一个关键的服务,可以被注入到controller中,注入其他服务却只能是$rootscope.scope是一个概念,是一个类,而$rootscope和被注入到cont ...

  8. Angular:手动脏检查/$apply/$digest和监控对象/$watch

    声明:借鉴好多chm资料.视频.PDF总结如下: 一.$apply的引入 View <div ng-app=""> <div ng-controller=&quo ...

  9. Angular - - $rootScope.Scope

    这里讲的是一些scope的操作,如创建/注销/各种监听及scope间的通信等等. $rootScope.Scope 可以使用$injector通过$rootScope关键字检索的一个根作用域. 可以通 ...

随机推荐

  1. MySQL开发总结(有点长..耐心看)

    一.理解MySQL基本概念 1.MySQL软件:MySQL实际上就是一软件,是一工具,是关系型数据库管理系统软件 2.MySQL数据库:就是按照数据结构来组织.存储和管理数据的仓库 3.MySQL数据 ...

  2. Saltstack自动化运维

    Saltstack三大功能 1,远程执行 2,配置管理(状态) 3,云管理 四种运行方式: Local         本地 Minion/Master C/S Syndic  代理模式 Salt S ...

  3. poj1151 Atlanis 线段树+离散化求矩形面积的并

    题目链接:http://poj.org/problem?id=1151 很经典的题目,网上有很多模板代码,自己理解了一天,然后很容易就敲出来了... 代码: #include<iostream& ...

  4. hdu1421 搬寝室 DP

    转载: /*证明:从4个数中 a b c d  依次递增: 选取相邻的两个数一定是最小得 及:(a-b)^2+(c-d)^2<(a-c)^2+(b-d)^2&&(a-b)^2+( ...

  5. [刷题]算法竞赛入门经典(第2版) 5-7/UVa12100 - Printer Queue

    题意:一堆文件但只有一个打印机,按优先级与排队顺序进行打印.也就是在一个可以插队的的队列里,问你何时可以打印到.至于这个插队啊,题目说"Of course, those annoying t ...

  6. 腾讯IVWEB团队:前端 fetch 通信

    欢迎大家关注腾讯云技术社区-博客园官方主页,我们将持续在博客园为大家推荐技术精品文章哦~ 作者:villainthr 文章摘自: 前端小吉米 随着前端异步的发展, XHR 这种耦合方式的书写不利于前端 ...

  7. pod lib lint 遇到的问题

    在pod lib lint(Xcode 8.3.2)校验组件是否有效的时候报了如下错误: - ERROR | [iOS] unknown: Encountered an unknown error ( ...

  8. PHP导出生成excel文件

    composer包管理工具还是非常好用的 下载安装的扩展比较靠谱 无需自己解决扩展BUG 省时省力提高效率 1.下载安装composer自行百度 2.通过composer下载安装office 3.不在 ...

  9. C#中设置TextBox控件中仅可以输入数字且设置上限

    首先设置只可以输入数字: 首先设置TextBox控件的KeyPress事件:当用户按下的键盘的键不在数字位的话,就禁止输入 private void textBox1_KeyPress(object ...

  10. 如何升级php版本---从php5.5.12 升级php7.1.5 wamp实践

    1.从官网下载一个php7.1.5 2.将刚下载的压缩包解压缩,修改命名为php7.1.5,即php+版本号. 3.将这个文件夹放在wamp/bin/php 目录下. 4.将原来版本的php5.5.1 ...