一点小说明
指令的作用:实现语义化标签
它就相当于为我们写了公共的自定义DOM元素或CLASS属性或ATTR属性,并且它不只是单单如此,你还可以在它的基础上来操作scope、绑定事件、更改样式等。通过这个Directive,我们可以封装很多公共指令,比如分页指令、自动补全指令等等。然后在HTML页面里只需要简单的写一行代码就可以实现很多强大的功能。
如何自定义指令
Angular是基于模块的框架,因此上来肯定要创建一个自己的模块:
var myAppModule = angular.module("myApp",[]);
然后在此模块基础上创建指令directive
myAppModule.directive("bingyu",function(){
return{
restrict:'AECM',
template:'<div>hello my directive</div>',
repalce:true
}
});
其中,bingyu是我们自定义标签的名字,后面跟着它的方法函数。
函数return了一个键值对组合,其中定义了标签的使用方法、属性等等内容。
那么看看它都定义了哪些内容吧:
1. restrict:定义了标签的使用方法,一共四种,分别是AECM
2. template:定义标签的模板。里面是用于替换自定义标签的字符串
3. repalce:是否支持替换
4. transclude:是否支持内嵌
如何使用指令
上面提到了标签的四种使用方法,即AECM。
A
attribute属性:当做属性来使用
<div xingoo></div>
E
element元素:当做标签元素来使用
<xingoo></xingoo>
C
class类:当做CSS样式来使用
<div class="xingoo"></div>
M
comments注释:当做注释使用(这种方式在1.2版本下亲测不可用!)
<!-- directive:xingoo -->
<div></div>
一般来说推荐,当做属性和元素来使用。
当想要在现有的html标签上扩展属性时,采用属性的方式。
当想要自定义标签时,采用标签的形式。
想要使用那种方式,必须要在定义directive中的restrict里面声明对应的字母。