你的位置:首页 > 软件开发 > Java > angular1.x 脏检测

angular1.x 脏检测

发布时间:2017-01-09 00:00:20
写在前面  双向绑定是angular的大亮点,然后支撑它的就是脏检测。一直对脏检测都有一些理解,却没有比较系统的概念。  以下是我阅读网上博文以及angular高级程序设计的理解与总结。  接收指导与批评。脏检查:  将原对象赋值一份快照。在某个时间,遍历比较这个对象和快照(新旧 ...

angular1.x 脏检测

写在前面

  双向绑定是angular的大亮点,然后支撑它的就是脏检测。一直对脏检测都有一些理解,却没有比较系统的概念。

  以下是我阅读网上博文以及angular高级程序设计的理解与总结。

  接收指导与批评。

脏检查:

  将原对象赋值一份快照。在某个时间,遍历比较这个对象和快照(新旧值),如果不一样就执行执行某些操作。

angular中的脏检查:

  1.不会检查所有的对象。当对象被绑定到html会检查,手动$scope.$watch()的会检查。检查的手段就是为这些对象创建(watcher)对象。并push到(watcher队列) 2.不会检查所有的属性。只要被绑定的属性才会被注册。 在angular程序初始化时,会将绑定的对象的属性添加为监听对象(watcher),也就是说一个对象绑定了N个属性,就会添加N个watcher。

angular注册watcher对象

  angualr会为每一个绑定到DOM的对象/对象的属性,创建一个watcher对象,(使用$scope.$watch()方法也会创建),watcher对象有好几个属性,(下面是笔者理解抽象出来的,并不是真的属性名

watch = { name:'',   //当前的watch 对象 观测的数据名,锁定监听的是什么 getNewValue:function($scope){ //获取监听属性的最新值   ...   return newValue;   }, listener:function(newValue,oldValue){ // 先比较新值与旧值判断是否继续执行,一般负责使用新值更新DOM页面,也可以是$watch方法注册的回调函数   ... }}

原标题:angular1.x 脏检测

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录