在angularJs应用启动之前,它们是以HTML文本形式存在文本编辑器当中。应用启动会进行编译和链接,作用域会同HTML进行绑定。这个过程包含了两个阶段!

编译阶段

  在编译的阶段,angularJs会遍历整个的文档并根据JavaScript中指令定义来处理页面上什么的指令。在遍历的过程中,有可能一层套着一层,一直延深处遍历。一但遍历和编译完毕就会返回一个叫做模板函数的函数。在这个函数没被返回(return)之前我们可以对编译后的DOM树进行修改。通常情况下,如果设置了compile函数,说明我们希望在指令和实时数据被放到DOM中之前
进行DOM操作,在这个函数中进行诸如添加和删除节点等DOM操作是安全的。本质上,当我们设置
了link选项,实际上是创建了一个postLink() 链接函数,以便compile() 函数可以定义链接函数。编译函数(compile)负责对模板DOM进行转换。
链接函数(link)负责将作用域和DOM进行链接。

1.compile

  compile选项可以返回一个对象或函数。

compile函数自身不会经常去写,但是link函数经常被使用。请看下面的例子

我们写了一个DIV标签,定义了一个autohello的一个属性,属性值5.   我们想把 “小平你好的这几句话”输出5遍。我们定义个一个compile 的函数,里面进行了一些DOM操作。在angularJs里面内置了一个小型的jq,所以我们可以用jq的写法来操作。

  页面输出如下:

在最后return一个闭包函数,其实就是我们的所说的link函数。平常我们这样定义的compile函数很少用,多种写法,因为写起来比较复杂。

    有的同学还挺好奇的,你不是说最后返回的函数是link吗?我可以写多个link函数嘛?为了满足同学的好奇心,我们可以这样改写

然后输出:不起作用哦!!如果同时设置了这两个选项,那么会把compile
所返回的函数当作链接函数,而link选项本身则会被忽略。

  那如果我们注释掉compile函数呢?结果会怎样呢?

  结果得出:这个link起作用哦。因为compile被注释掉了

最新文章

  1. ADO.NET五大对象理论和实践(草稿)
  2. 进程间通信--pipe
  3. STL源码--序列式容器
  4. 嵌入式Linux驱动学习之路(二)u-boot体验
  5. Centos上的安装openoffice+unoconv+swftools (转)
  6. Shodan!
  7. Asp.Net Core- 配置组件详解
  8. 客户端session与服务端session
  9. Nvidia显卡怎样查看显存大小及硬件相关信息
  10. Android应用开发基础篇(3)-----ListView
  11. linux安装Eclipse c++环境
  12. Android数据库高手秘籍(五)——LitePal的存储操作
  13. javaSE_06Java中的数组(array)-练习
  14. Spring注解AOP及单元测试junit(6)
  15. 转发 .Net平台下ActiveMQ入门实例 https://www.cnblogs.com/madyina/p/4121458.html
  16. hikari链接池
  17. Feign自定义编程配置
  18. [Python]编码声明:是coding:utf-8还是coding=urf-8呢
  19. c++11 输出时间
  20. Centos 7 下 Mysql 5.7 Galera Cluster 集群部署

热门文章

  1. Axure7.0 以及 中文汉化语言包下载 axure汉化包
  2. url斜杠问题——重定向
  3. JSP的常用指令有哪些?
  4. 通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应, 请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法, 参数不同时,方法能重载吗?
  5. SpingMvc中的控制器的注解一般用那个,有没有别的注解可以替代?
  6. java-流式编程
  7. MyBatis Plus 2.3 个人笔记-03-Active Record
  8. 查看mysql相关信息
  9. servlet中的ServletContext对象
  10. LQR (线性二次型调节器)的直观推导及简单应用