`
huangyongxing310
  • 浏览: 498774 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

Anguar 工作过程

阅读更多
Anguar 工作过程



Anguar的指令编译过程:
1.首先加载angularjs库,查找到ng-app指令,从而找到应用的边界,
2.根据ng-app划定的作用域来调用$compile服务进行编译,angularjs会遍历整个HTML文档,并根据js中指令的定义来处理在
页面上声明的各个指令按照指令的优先级(priority)排列
3.根据指令中的配置参数(template,place,transclude等)转换DOM然后就开始按顺序执行各指令的compile函数(如果指令
上有定义compile函数)对模板自身进行转换
4.注意:此处的compile函数是我们指令中配置的,跟上面说的$compile服务不一样。每个compile函数执行完后都会返回一个
link函数,所有的link函数会合成一个大的link函数
5.然后这个大的link函数就会被执行,主要做数据绑定,通过在DOM上注册监听器来动态修改scope中的数据,或者是使用
$watchs监听 scope中的变量来修改DOM,从而建立双向绑定等等。
6.若我们的指令中没有配置compile函数,那我们配置的link函数就会运行,她做的事情大致跟上面complie返回之后所有的
link函数合成的的大的link函数差不多。
7.所以:在指令中compile与link选项是互斥的,如果同时设置了这两个选项,那么就会把compile所返回的函数当做是链接
函数,而link选项本身就会被忽略掉


参考原文:http://www.jb51.net/article/83051.htm
分享到:
评论

相关推荐

    anguar 表单验证指令

    angular 指令用于表单验证 资源描述可以把电子书的概述、源代码的说明、文档的片段填在这里,描述详细会获得我们的推荐,更容易被他人下载

    angular学习视频

    AngularJS 把应用程序数据绑定到 HTML 元素。 AngularJS 可以克隆和重复 HTML 元素。 AngularJS 可以隐藏和显示 HTML 元素。 AngularJS 可以在 HTML 元素"背后"添加代码。 AngularJS 支持输入验证。

    anguar-testapp

    测试应用 该项目是使用版本11.2.4生成的。 开发服务器 为开发服务器运行ng serve 。... 如果您更改任何源文件,该应用程序将自动重新加载。 代码脚手架 运行ng generate component component-name生成一个新的组件。...

    angular-karma-test:anguar 应用业力测试样本

    角业力测试关于通过 karma 测试 Angular 应用程序的示例项目安装并运行 npm install -g http-servergit clone https://github.com/rotoshine/angular-karma-test.gitcd angular-karma-testnpm install# 테스트를 1회...

    angularjs Web页面框架 jsp源码

    - **依赖注入**:AngularJS自动管理对象的创建和依赖关系,开发者无需关心实例化过程。 2. **控制器**: - 在AngularJS中,控制器是JavaScript函数,通过`ng-controller`指令附加到DOM元素,它们与视图交互并处理...

    anguar-jwt:使用 AngularJS 和 NodeJS 进行基于令牌的身份验证

    2. JWT的工作原理和组成部分,以及如何使用`jsonwebtoken`库生成和验证JWT。 3. Express框架构建API服务器和处理HTTP请求。 4. 安全性措施,如防止CSRF攻击和密码安全处理。 5. 刷新令牌的概念,用于在JWT过期后的...

    bolg:前端 anguar+requirejs php 构建我的 bolg 域

    关于 这是一个分支,但需要对 requireJS 支持进行更改。 AngularJS 1.2.18 RequireJS 2.1.14 完全支持单元和 e2e 测试 支持 Karma Test Runner 0.10+(以前的 Testacular) 变化 要运行 e2e 测试,您需要运行...

    hypervideo:html5 视频播放 + anguarjs

    它采用MVVM(Model-View-ViewModel)设计模式,通过数据绑定和依赖注入,简化了前端开发过程。将AngularJS应用于HTML5视频,可以实现诸如时间戳选择、视频进度控制、互动问答等高级交互功能。 在描述中提到的“超...

    slush-asponte:一个 slush 生成器,用于构建基于 Anguar-JS ECMAScript6 的前端,并具有可靠的开发人员工具包和构建流程

    阿斯邦特 一个 slush 生成器,用于使用可靠的开发人员工具包和构建过程来搭建基于 AngularJS/ECMAScript6 的前端。 Asponte 是拉丁语sua sponte 的戏剧,意思是“自己的意志”。 之所以如此命名此生成器,是因为您的...

    angularjs做的表格

    这是我写的angularjs开发的表格 可以添加主菜单 子菜单 有查询功能被我注掉了 有问题可以给我留言

    Inventory-Management-App:一个简单的演示应用程序,用于展示Spring Data和Spring Boot OAuth2实现

    库存管理应用一个简单的演示应用程序,用于展示Spring Data和Spring Boot OAuth2实现。 该项目是为学习目的而设计的,但随时可以提出要求!入门这些说明将为您提供在本地计算机上运行并运行的项目的副本,以进行开发...

    SpotyApp:使用angular和spofity API制作的spofity克隆

    Spotiapp 该项目是使用版本9.1.12生成的。开发服务器为开发服务器运行ng serve 。... 如果您更改任何源文件,该应用程序将自动重新加载。代码脚手架运行ng generate component component-name生成一个新的组件。...

    generator-jhipster-angular-flex

    发电机-jhipster-角柔性 JHipster蓝图,此模块扩展了有角度的客户端,以使用生成的物料卡为每个实体提供灵活的布局,并为每个实体提供列表视图。 此模块将@ angular / material导入到vendor.scss文件中,并修改app....

    angular实现图片懒加载实例代码

    在开发过程中,遇到问题不要气馁,多尝试不同的解决方案,结合插件文档和社区资源,往往能找到合适的答案。希望这篇文章能对你在AngularJS图片懒加载的道路上提供帮助,并激发你进一步探索前端性能优化的兴趣。

    AngularJS中$interval的用法详解

    总的来说,`$interval` 是AngularJS中用于实现周期性任务的重要工具,它允许开发者在AngularJS的上下文中安全地执行定时操作,并提供了丰富的回调机制来处理任务的完成、错误和执行过程。通过合理使用`$interval`,...

    AngularJS实践之使用ng-repeat中$index的注意点

    有一次我们在工作中碰到了这个问题。 要定位这个BUG非常麻烦, 因为客户也不清楚如何重现这个问题。 后来发现这个Bug是由于在 ng-repeat 中使用了 $index 引发的。 一个简单动作(action)的列表 先来看看一个完整有效...

    ngx-videogular:更新了Angular 10的Videogular

    7. 进行测试:使用提供的测试文件进行组件功能验证,确保在不同场景下正常工作。 总之,ngx-videogular的更新确保了与Angular 10及更高版本的兼容性,利用了TypeScript的最新特性,提升了组件的稳定性和效率。...

    解决angular的$http.post()提交数据时后台接收不到参数值问题的方法

    在开发Web应用时,我们经常遇到前端与后端数据交互的问题。...本文将针对这一问题,探讨解决方案,并分析原因。...同时,为了保证良好的前后端交互,确保在开发过程中对HTTP请求头和内容类型有清晰的理解,是非常重要的。

    Angular-Chat-App:使用Angular 6创建的聊天应用

    聊天应用 该项目是使用版本6.0.8生成的。 开发服务器 为开发服务器运行ng serve 。... 如果您更改任何源文件,该应用程序将自动重新加载。 代码脚手架 运行ng generate component component-name生成一个新的组件。...

Global site tag (gtag.js) - Google Analytics