揭秘AngularJS工作原理
2015-09-05 10:47
645 查看
从本质上讲,在浏览器加载AngularJS web应用的方式与加载非AngularJS引用的方式一样。但是,它们的运行方式略有不同。
当浏览器触发DOMContentLoaded事件时,AngularJS就开始工作。它首先寻找ng-app指令。[加载AngularJS时,如果document.readyState被设置为complete,AngularJS也会启动初始化。]
如果浏览器在DOM中找到ng-app指令,它会为我们自动启动应用。如果没有找到这个指令Angular期望我们自己手动启动应用。要手动启动一个AngularJS应用,可以使用Angular的bootstrap()方法。
注意:使用bottstrap()方法只能启动Angular应用一次。
Angular会使用ng-app指令的值配置injector服务。一旦应用程序加载完成,injector服务。
一旦应用程序加载完成,injector就会在应用程序创建compile服务。compile服务。rootScope创建完成后,compile服务就会接管它。它将compile服务就会接管它。它将rootScope与现有的DOM连接起来,然后从设置ng-app指令为根元素的地方开始编译DOM。
当Angular.js被取回时,浏览器会执行它,同时设置一个事件监听器来监听浏览器的DOMContentLoaded事件。
注意:DOMContentLoaded事件会在HTML文档加载完成并开始解析时触发。
Angular进入digest循环时,会等待digest循环时,会等待evalAsync队列清空,此外digest循环还会等待digest循环还会等待watch没有东西改变。然后将回调执行上下文交还给浏览器,DOM将会被渲染到指令的位置。
[转载请标明出处:]http://blog.csdn.net/ligang2585116]
当浏览器触发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服务。
一旦应用程序加载完成,injector就会在应用程序创建compile服务。compile服务。rootScope创建完成后,compile服务就会接管它。它将compile服务就会接管它。它将rootScope与现有的DOM连接起来,然后从设置ng-app指令为根元素的地方开始编译DOM。
一、视图的工作原理:
浏览器在提取脚本时(从script标签中),会暂停DOM解析并等待脚本取回。当Angular.js被取回时,浏览器会执行它,同时设置一个事件监听器来监听浏览器的DOMContentLoaded事件。
注意:DOMContentLoaded事件会在HTML文档加载完成并开始解析时触发。
二、编译阶段:
compile服务会遍历DOM树并搜集它找到的所有指令,然后将所有指令的链接函数合并为一个单一的链接函数。然后这个链接函数会将编译好的模板连接到$rootScope中。三、运行时
当事件被触发时,事件处理程序就会在指令(AngularJS)的上下文中进行调用。AngularJS会在包含作用域apply()方法内调用指令。Angular在apply()方法内调用指令。Angular在rootScope上启动$digest循环时开始整个过程的,并会传播到所有子作用域中。Angular进入digest循环时,会等待digest循环时,会等待evalAsync队列清空,此外digest循环还会等待digest循环还会等待watch没有东西改变。然后将回调执行上下文交还给浏览器,DOM将会被渲染到指令的位置。
[转载请标明出处:]http://blog.csdn.net/ligang2585116]
相关文章推荐
- AngularJS的双向数据绑定
- 【转】angular学习笔记(十四)-$watch(1)
- 【转】AngularJS的$resource
- AngularJS 拦截器和好棒例子
- [Angularjs]ng-file-upload上传文件
- 【转】Angular运行原理揭秘 Part 1
- Angular Input格式化
- AngularJS内置指令
- 理解angular中的module和injector,即依赖注入
- Regionals 2014 >> North America - Greater NY >> 7097 - Growing Rectangular Spiral
- angular 路由跳转 route
- 第一个Angularjs前瑞框架项目
- angular 入门调试遇到的问题
- Angular实现递归指令 - Tree View
- 【转】angular Ajax请求
- 【转】AngularJS路由和模板
- angularjs学习笔记—工具方法
- JS调用AngularJS中的方法
- angularjs常用代码块
- [AngularJS系列(4)] 那伤不起的provider们啊~ (Provider, Value, Constant, Service, Factory, Decorator)