Directive - Compile vs. Link
2016-04-28 15:05
676 查看
还是先从栗子们看起~
如果我想实现这样一个功能,当一个input失去光标焦点时(blur),执行一些语句,比如当输入用户名后,向后台发ajax请求查询用户名是否已经存在,好有及时的页面相应。
输入 hellobug
失去焦点后提示 hellobug 这个用户名已经存在
代码如下:
HTML
controller和directive的定义
在上面的例子里,directive返回对象里定义的
如果是只有
directive的简单写法
再来这样一个功能,我想让内容为
-_-,我知道
HTML
directive的定义
在上面例子的
什么时候用compile,什么时候用link呢,或者两者可不可以一起用呢?
先从directive是如何在angular手下生效的说起吧~
将html转化成dom,所以自定义的html标签必须符合html的格式
搜索匹配directive,按照
执行directive上的
简单的说就是为了解决性能问题,特别是那种model变化会影响dom结构变化的,而变化的结构还会有新的scope绑定及事件绑定,比如
在compile阶段要执行的函数,返回的function就是link时要执行的function
常用参数为
较少使用,因为大部分directive是处理dom元素的行为绑定,而不是改变它们
在link阶段要执行的函数,这个属性只有当compile属性没有设置时才生效
常用参数为
directive基本上都会有此函数,可以注册事件,并与scope相绑
想在dom渲染前对它进行变形,并且不需要scope参数
想在所有相同directive里共享某些方法,这时应该定义在compile里,性能会比较好
返回值就是link的function,这时就是共同使用的时候
对特定的元素注册事件
需要用到scope参数来实现dom元素的一些行为
本节目所用示例可以猛戳这里查看ho~
原文地址
如果我想实现这样一个功能,当一个input失去光标焦点时(blur),执行一些语句,比如当输入用户名后,向后台发ajax请求查询用户名是否已经存在,好有及时的页面相应。
输入 hellobug
失去焦点后提示 hellobug 这个用户名已经存在
代码如下:
HTML
1 2 3 4 5 6 | <body ng-controller="MainCtrl"> <lable>用户名: <input type="text" ng-model="username" ng-blur="checkUsername()" /> <span style="color:red;" ng-show="usernameAlreadyExist">用户名已经存在</span> </lable> </body> |
1 2 3 4 5 67 | app.controller('MainCtrl', function($scope) { $scope.checkUsername = function() { //send ajax to check on server if ($scope.username === 'hellobug') { $scope.usernameAlreadyExist = true; } } }); app.directive('ngBlur', function($document) { return { link: function(scope, element, attrs) { $(element).bind('blur', function(e){ scope.$apply(attrs.ngBlur); }); } } }) |
link方法在blur事件触发时执行了scope上的
checkUsername()方法。
如果是只有
link方法,也可以简单的写成下面这种形式~直接返回
link对应的function~
directive的简单写法
1 2 3 4 5 67 | app.directive('ngBlur', function($document) { return function(scope, element, attrs) { $(element).bind('blur', function(e){ scope.$apply(attrs.ngBlur); }); }; }) |
哈哈哈哈的dom元素重复n遍,n是自定义的,以达到某种满屏大笑丧心病狂的效果
-_-,我知道
ng-repeat就已经能干这事儿了,但是如果自己实现一下呢~
HTML
1 2 3 | <ul repeater="20"> <li>哈哈哈哈</li> </ul> |
1 2 3 4 5 67 | app.directive('repeater', function($document) { return { restrict: 'A', compile: function(element, attrs) { var template = $(element).children().clone(); for(var i=0; i<attrs.repeater - 1; i++) { $(element).append(template.clone()); } } } }); |
compile方法里,子元素被复制成了
repeater制定的数量。
什么时候用compile,什么时候用link呢,或者两者可不可以一起用呢?
先从directive是如何在angular手下生效的说起吧~
编译三阶段:
1. 标准浏览器API转化
将html转化成dom,所以自定义的html标签必须符合html的格式
2. Angular compile
搜索匹配directive,按照priority排序,并执行directive上的
compile方法
3. Angular link
执行directive上的link方法,进行scope绑定及事件绑定
为什么编译的过程要分成compile和link?
简单的说就是为了解决性能问题,特别是那种model变化会影响dom结构变化的,而变化的结构还会有新的scope绑定及事件绑定,比如ng-repeat
compile
和link
的形式
compile
function compile(element, attrs, transclude) { ... }
在compile阶段要执行的函数,返回的function就是link时要执行的function
常用参数为
element和
attrs,分别是dom元素和元素上的属性们,其它的以后细说
较少使用,因为大部分directive是处理dom元素的行为绑定,而不是改变它们
link
function link(scope, element, attrs, controller) { ... }
在link阶段要执行的函数,这个属性只有当compile属性没有设置时才生效
常用参数为
scope,
element和
attrs,分别是当前元素所在的scope,dom元素和元素上的属性们,其它的以后细说
directive基本上都会有此函数,可以注册事件,并与scope相绑
compile
和link
的使用时机
compile
想在dom渲染前对它进行变形,并且不需要scope参数想在所有相同directive里共享某些方法,这时应该定义在compile里,性能会比较好
返回值就是link的function,这时就是共同使用的时候
link
对特定的元素注册事件需要用到scope参数来实现dom元素的一些行为
最后~
本节目所用示例可以猛戳这里查看ho~原文地址
相关文章推荐
- 把网站链接卖一个好价钱: Text Link Ads 注册网赚攻略
- css import与link的区别
- AngularJS基础教程之简单介绍
- Oracle创建Database Link的两种方式详解
- AngularJS中处理多个promise的方式
- angularJS 中$attrs方法使用指南
- AngularJS实现textarea记录只能输入规定数量的字符并显示
- 深入浅析AngularJS和DataModel
- 简述AngularJS相关的一些编程思想
- 不能不知道的10个angularjs英文学习网站
- AngularJS中的$watch(),$digest()和$apply()区分
- AngularJS的一些基本样式初窥
- 简单讲解AngularJS的Routing路由的定义与使用
- 创建你的第一个AngularJS应用的方法
- 详解AngularJS中的作用域
- Angular发布1.5正式版,专注于向Angular 2的过渡
- 简介AngularJS的视图功能应用
- AngularJS语法详解
- AngularJS 2.0新特性有哪些
- AngualrJS中的Directive制作一个菜单