JSON

学习笔记-AngularJs(十)

字号+ 作者:H5之家 来源:H5之家 2015-10-20 10:02 我要评论( )

学习笔记-AngularJs(十),前面一直在说自定义指令,但是却一直没有一次系统地去了解,现在需要我们一起来学习如何去使用自定义指令,去丰富html标签、属性,实

前面一直在说自定义指令,但是却一直没有一次系统地去了解,现在需要我们一起来学习如何去使用自定义指令,去丰富html标签、属性,实现多元化、多功能的标签(或是属性)。辣么,啥是指令?要了解指令,首先需要了解AngularJs的HTML编译器,简单地说让浏览器认识你自定义指令或是Angular的指令集,将其行为运用到DOM上(视图),分两个过程编译和链接,编译阶段是遍历DOM并且收集所有的相关指令,生成一个链接函数;链接阶段是给通过编译阶段调用所说的链接函数来将模板与作用域链接起来,绑定一个作用域,生成一个动态的视图。作用域模型的任何改变都会反映到视图上,并且视图上的任何用户操作也都会反映到作用域模型。

那么说到底,由某个属性、元素名称、css类名出现而导致的行为,或者说是DOM的变化,能让你以一种声明式的方法来扩展HTML表示能力,这就是指令!

官网也写了一个比较详细的指令demo(具体属性分析如下):

var myModule = angular.module(...);
myModule.directive('directiveName', function factory(injectables) { //工厂函数里面injectables是何意呢?望知道的人告知
var directiveDefinitionObject = {
priority: 0, //优先级priority,Dom里面会有很多指令,定义优先级,可以使此指令优先执行
terminal:false, //如果被设置为true,那么该指令就会在同一个DOM的指令集和中最后被执行
template: '<div></div>', // or // function(tElement, tAttrs) { ... },
// templateUrl: 'directive.html', // or // function(tElement, tAttrs) { ... }, //template或templateUrl顾名思义就是模板文件,可以编写,也可以url,也可以是function(tElement,tAttrs){ return ... ;}
replace: false, //是否替换现在的元素
transclude: false, //重要属性之一,配合ng-transclude使用,为true时,可以将原元素的内容(html、其他指令)提取到带有指令ngTransclude的元素内,下面有例子说明!(注:指令的内部可以访问外部指令的作用域,并且模板也可以访问外部的作用域对象)
restrict: 'A', //以哪种形式声明指令行为的格式,有AECM,分别是属性<div my-directive="exp"> </div> 、元素*<my-directive></my-directive> 、 class*<div></div> 、注释<!-- directive: my-directive exp -->
templateNamespace: 'html', //模板的命名空间,有'html'、'svg'等,默认为'html'
scope: false, //是否创造一个新的作用域(针对指令)
/*scope是最难理解的一个属性*/
controller: function($scope, $element, $attrs, $transclude, otherInjectables) {...
}, //控制器的构造对象,预编译阶段执行,$scope当前作用域,$element当前元素,$attrs当前元素的属性集合,并且它是共享的,其他指令可以通过它的名字得到(参考依赖属性(通过require属性引入)。这就使得指令间可以互相交流来扩大自己的能力。当然也可以是控制 器名字(那么此控制器需要在应用声明好,这样便可以通过注入$attrs、$element操纵指令对应模板的dom),$transclude,用来操作嵌入作用域对应的dom,也就是被提取到ngTransclude的元素里面的dom了,下面有例子说明!
controllerAs: 'stringAlias', //定义控制器的别名
require: 'siblingDirectiveName', // or // ['^parentDirectiveName', '?optionalDirectiveName', '?^optionalParent'], // 请求将另一个控制器作为参数传入到当前链接函数。 这个请求需要传递被请求指令的控制器的名字。之前有例子关于表单自定义 验证有使用到,学习笔记-AngularJs(八)
compile: function compile(tElement, tAttrs, transclude) { //tElement指令所在的元素,tAttrs指令所在元素属性集合
return {
pre: function preLink(scope, iElement, iAttrs, controller) {...
},
post: function postLink(scope, iElement, iAttrs, controller) {...
}
}
// or
// return function postLink( ... ) { ... } //编译函数是用来处理需要修改模板DOM(执行于放到dom之前的dom操作)的情况的。因为大部分指令都不需要修改模板,所以这个函数也不常用。返回的是函数或是对象,返回函数时等效于link链接函数
},
// or
// link: { //链接函数负责注册DOM事件和更新DOM。它是在模板被克隆之后执行的。 它也是大部分指令逻辑代码编写的地方。scope当前作用域,iElement当前元素,iAttrs当前元素的属性集合,controller就是上面require属性的值,于是就可以调用require进来的控制 器的属性方法,(包括之前讲的ngModel或是其他指令controller和controllerAs定义的有控制器名的控制器方法)
// pre: function preLink(scope, iElement, iAttrs, controller) { ... }, // post: function postLink(scope, iElement, iAttrs, controller) { ... } // } // or // link: function postLink( ... ) { ... }
};
return directiveDefinitionObject;
});

compile和link选项是互斥的。如果同时设置了这两个选项,那么会把compile所返回的函数当作链接函数,而link选项本身则会被忽略。

编译函数负责对模板DOM进行转换。链接函数负责将作用域和DOM进行链接。

上面demo有些属性在实际操作上,都是取默认的属性,那么官网将其简化成了这个样子:


学习笔记-AngularJs(十)


var myModule = angular.module(...);
myModule.directive('directiveName', function factory(injectables) { //此处需要注意,在视图引入指令时,采用的是骆峰命名法,所以调用时应该是directive-name
var directiveDefinitionObject = {
link: function postLink(scope, iElement, iAttrs) { ... }
};
return directiveDefinitionObject;
// or
// return function postLink(scope, iElement, iAttrs) { ... }
}); View Code

到这里还是需要编写些demo,才能起到学习的效果!

在之前的 学习笔记-AngularJs(八) 里面就有一个自定义表单验证的demo,情景是这样的,在input框里面不能写入“xiaobin”,主要是对ngModel中 $setValidity(validationErrorKey, isValid); 和 $setViewValue(value, trigger); 在双向绑定中是如何实现scope->view、view->scope之间的那个验证和格式化的学习,没看过的话,可以去看一下,虽然理解得不透彻!下面贴一下主要代码:


学习笔记-AngularJs(十)


var custom = angular.module('customControl', ['ngSanitize']);
custom.directive("noxiaobin", function () {
return {
restrict: "A",
require: "?ngModel",
link: function (scope, element, attrs, ngModel) {
if (!ngModel) return;
ngModel.$parsers.push(function (v) { //传说中的验证器
if (v != "xiaobin") {
ngModel.$setValidity('noxiaobin', true); //通过获取从dom过来的值,然后进行验证,使用$setValidity('noxiaobin', true);改变noxiaobin的值,然后反馈会dom
return v;
} else {
ngModel.$setValidity('noxiaobin', false);
return undefined;
}
});
}
}
}); View Code

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • JS学习笔记9_JSON

    JS学习笔记9_JSON

    2015-11-21 09:00

  • Shunter - a Node.js application built to read JSON and trans

    Shunter - a Node.js application built to read JSON and trans

    2015-11-17 11:39

  • json学习小记

    json学习小记

    2015-11-10 11:25

  • 使用Grunt构建自动化开发环境

    使用Grunt构建自动化开发环境

    2015-10-24 10:41

网友点评
i