$compile 和$link
来源:互联网 发布:什么是碎片化阅读 知乎 编辑:程序博客网 时间:2024/04/29 07:06
实际上link其实是由$compile生成的函数,而且这个函数在生成的时候内容已经定好了,所以在调用link函数的时候只是
传对应的scope参数给这些由$compile编译好的link函数,所以如果想通过cloneAttachFn这个传入link的回调函数来修改dom结构是不行的。
$compile
最基本的使用方式:
var link = $compile('<p>{{ text }}</p>');var node = link($scope);console.log(node);
上面的 $compile
和 link
调用时都有额外参数来实现其它功能。先看 link
函数,它形如:
function(scope[, cloneAttachFn]
第二个参数 cloneAttachFn
的作用是,表明是否复制原始节点,及对复制节点需要做的处理,下面这个例子说明了它的作用:
<div ng-controller="TestCtrl"></div><div id="a">A {{ text }}</div><div id="b">B </div>
app.controller('TestCtrl', function($scope, $compile){ var link = $compile($('#a')); //true参数表示新建一个完全隔离的scope,而不是继承的child scope var scope = $scope.$new(true); scope.text = '12345'; //var node = link(scope, function(){}); var node = link(scope); $('#b').append(node);});
cloneAttachFn
对节点的处理是有限制的,你可以添加 class
,但是不能做与数据绑定有关的其它修改(修改了也无效):
app.controller('TestCtrl', function($scope, $compile){ var link = $compile($('#a')); var scope = $scope.$new(true); scope.text = '12345'; var node = link(scope, function(clone_element, scope){ clone_element.text(clone_element.text() + ' ...'); //无效 clone_element.text('{{ text2 }}'); //无效 clone_element.addClass('new_class'); }); $('#b').append(node);});
修改无效的原因是,像 {{ text }}
这种所谓的 Interpolate 在 $compile
中已经被处理过了,生成了相关函数(这里起作用的是 directive
中的一个 postLink
函数),后面执行 link
就是执行了$compile
生成的这些函数。当然,如果你的文本没有数据变量的引用,那修改是会有效果的。
前面在说自定义指令时说过, link
函数是由 compile
函数返回的,也就像前面说的,应该把改变 DOM 结构的逻辑放在 compile
函数中做。
0 0
- $compile 和$link
- COMPILE && LINK
- 编译和链接(compile and link)
- angular之link和compile的区别
- angular中compile和link的区别
- 指令compile和link函数解析
- angular中compile和link函数详解
- Angularjs link和compile使用区别
- angularjs compile和link的区别
- angular之link和compile的区别
- angular中的compile和link函数
- 详解compile & link
- Directive - Compile vs. Link
- angularjs compile link
- compile与link区别
- angularjs指令compile、link
- NASM Intro - Compile and Link
- GCC Compile and Link options
- Android M 动态权限获取
- 编码风格
- JavaScript常用的一些东西
- android 事件分发机制一
- 微信公众号开发之JSSDK:记config:invalid signature 的错误排查
- $compile 和$link
- Netty原理和使用
- 选择排序 Fortran代码
- MyEclipse内存溢出问题解决方法
- 程序员需要具备的基本技能
- oracle 触发器的种类和触发事件,DML触发器,DDL事件触发器,替代触发器,查看触发器,
- Frame和bounds详解
- 矩形窗的频谱泄露
- ASP.Net MVC开发基础学习笔记(7):数据查询页面