首页 > Web开发 > 详细

angularjs学习:$digest

时间:2015-06-04 12:09:29      阅读:303      评论:0      收藏:0      [点我收藏+]

angularjs扩展了javascript的事件流程机制:它会扩展这个标准的浏览器流程,创建一个Angular上下文。这个Angular上下文指的是运行在Angular事件循环内的特定代码,该Angular事件循环通常被称作$digest循环。

$digest循环有两个主要组成部分:

    1$watch列表

    2$evalAsync列表

$digest循环过程:

1.绑定$scope对象的UI元素会添加一个$watch到$watch列表中,$watch列表会通过一个叫做“脏值检查”的程序解析

2.脏值检查:Angular会遍历$watch列表,如果从旧值更新后的值没有发生变化,它会继续遍历监控列表。如果值发生了变化,该应用会启用新值并继续遍历$watch列表,只要有任何值发生变化,应用将会退回到$watch循环中,
直到检测到不再有任何变化。
技术分享


3.新的$digest循环没有检测到变化。

4.浏览器拿回控制权,更新与$scope.name新值相应部分的DOM。

================================================================

angularjs是通过$apply来触发angular上下文的,然后进入$digest循环。

angularjs学习:$digest

原文:http://my.oschina.net/haoqoo/blog/424626

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!