揭秘AngularJS工作原理

从本质上讲,在浏览器加载AngularJS web应用的方式与加载非AngularJS引用的方式一样。但是,它们的运行方式略有不同。

当浏览器触发DOMContentLoaded事件时,AngularJS就开始工作。它首先寻找ng-app指令。[加载AngularJS时,如果document.readyState被设置为complete,AngularJS也会启动初始化。]

如果浏览器在DOM中找到ng-app指令,它会为我们自动启动应用。如果没有找到这个指令Angular期望我们自己手动启动应用。要手动启动一个AngularJS应用,可以使用Angular的bootstrap()方法。

var ele = document.createElement("div");
Angular.bootstrap(ele, ['myApp']);
Angular.bootstrap(document, ['myApp']);

注意:使用bottstrap()方法只能启动Angular应用一次。

Angular会使用ng-app指令的值配置 injector injector就会在应用程序创建 compile rootScope创建完成后, compile rootScope与现有的DOM连接起来,然后从设置ng-app指令为根元素的地方开始编译DOM。

一、视图的工作原理:

浏览器在提取脚本时(从script标签中),会暂停DOM解析并等待脚本取回。
当Angular.js被取回时,浏览器会执行它,同时设置一个事件监听器来监听浏览器的DOMContentLoaded事件。

注意:DOMContentLoaded事件会在HTML文档加载完成并开始解析时触发。

二、编译阶段:

compile服务会遍历DOM树并搜集它找到的所有指令,然后将所有指令的链接函数合并为一个单一的链接函数。然后这个链接函数会将编译好的模板连接到$rootScope中。

三、运行时

当事件被触发时,事件处理程序就会在指令(AngularJS)的上下文中进行调用。AngularJS会在包含作用域 apply()Angular rootScope上启动$digest循环时开始整个过程的,并会传播到所有子作用域中。

Angular进入 digest evalAsync队列清空,此外 digest watch没有东西改变。然后将回调执行上下文交还给浏览器,DOM将会被渲染到指令的位置。

[转载请标明出处:http://blog.csdn.net/ligang2585116]

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋飛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值