AngularJS  自定义指令详解及实例代码


Posted in Javascript onSeptember 14, 2016

AngularJS支持用户自定义标签属性,在不需要使用DOM节点操作的情况下,添加自定义的内容。

前面提到AngularJS的四大特性:

1 MVC

2 模块化

3 指令

4 双向数据绑定

下面将会介绍如下的内容:

1 如何自定义指令

2 自定义指令的使用

3 自定义指令的内嵌使用

如何自定义指令:

Angular是基于模块的框架,因此上来肯定要创建一个自己的模块:

var myAppModule = angular.module("myApp",[]);

然后在此模块基础上创建指令directive      

myAppModule.directive("xingoo",function(){
    return{
     restrict:'AECM',
     template:'<div>hello my directive</div>',
     repalce:true
    }
   });

其中,xingoo是我们自定义标签的名字,后面跟着它的方法函数。

函数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里面声明对应的字母。 

指令的内嵌使用:

因为标签内部可以嵌套其他的标签,因此想要在自定义标签中嵌套其他的元素标签,则需要:

1 使用transclude属性,设置为true。

2 并使用ng-transclude属性,定义内部嵌套的位置。

代码如下:      

myAppModule.directive("test",function(){
    return{
     restrict:'AECM',
     transclude:true,
     template:"<div>haha! <div ng-transclude></div> wuwu!</div>"
    }
   });
 

全部代码

<!doctype html>
<html ng-app="myApp">
 <head>
   <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
   <script src="http://apps.bdimg.com/libs/angular.js/1.2.16/angular.min.js"></script>
 </head>
 <body>
  
  <xingoo></xingoo>
  <div xingoo></div>
  <div class="xingoo"></div>
  <!-- directive:xingoo -->
  <div></div>
  <hr>
  <xingoo>3333</xingoo>
  <hr>
  <test>4444</test>


  <script type="text/javascript">
   var myAppModule = angular.module("myApp",[]);

   myAppModule.directive("xingoo",function(){
    return{
     restrict:'AECM',
     template:'<div>hello my directive</div>',
     repalce:true
    }
   });

   myAppModule.directive("test",function(){
    return{
     restrict:'AECM',
     transclude:true,
     template:"<div>haha! <div ng-transclude></div> wuwu!</div>"
    }
   });
  </script>
 </body>
</html>

运行结果

AngularJS  自定义指令详解及实例代码

以上就是对AngularJS 自定义指令的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

Javascript 相关文章推荐
JS 事件绑定函数代码
Apr 28 Javascript
javascript 闭包疑问
Dec 30 Javascript
jquery中选择块并改变属性值的方法
Jul 31 Javascript
点击弹出层效果&amp;弹出窗口后网页背景变暗效果的实现代码
Feb 10 Javascript
微信小程序中子页面向父页面传值实例详解
Mar 20 Javascript
vue2.0 + ele的循环表单及验证字段方法
Sep 18 Javascript
vue.js 2.0实现简单分页效果
Jul 29 Javascript
微信接入之获取用户头像的方法步骤
Sep 23 Javascript
layui-select动态选中值的例子
Sep 23 Javascript
element表格翻页第2页从1开始编号(后端从0开始分页)
Dec 10 Javascript
JavaScript进阶(二)词法作用域与作用域链实例分析
May 09 Javascript
vue 根据选择的月份动态展示日期对应的星期几
Feb 06 Vue.js
AngularJS 自定义过滤器详解及实例代码
Sep 14 #Javascript
AngularJS 中的Promise --- $q服务详解
Sep 14 #Javascript
AngularJS bootstrap启动详解及实例代码
Sep 14 #Javascript
AngularJS equal比较对象实例详解
Sep 14 #Javascript
AngularJS API之copy深拷贝详解及实例
Sep 14 #Javascript
AngularJS $injector 依赖注入详解
Sep 14 #Javascript
详解XMLHttpRequest(二)响应属性、二进制数据、监测上传下载进度
Sep 14 #Javascript
You might like
DOTA2【瓜皮时刻】Vol.91 RTZ山史最惨“矿难”
2021/03/05 DOTA
全局记录程序片段的运行时间 正确找到程序逻辑耗时多的断点
2011/01/06 PHP
thinkphp判断访客为手机端或PC端的方法
2014/11/24 PHP
javascript第一课
2007/02/27 Javascript
JS获取月份最后天数、最大天数与某日周数的方法
2015/12/08 Javascript
JavaScript中关联原型链属性特性
2016/02/13 Javascript
JQuery EasyUI学习教程之datagrid 添加、修改、删除操作
2016/07/09 Javascript
axios中cookie跨域及相关配置示例详解
2017/12/20 Javascript
原生JS实现前端本地文件上传
2018/09/08 Javascript
js自定义input文件上传样式
2018/10/26 Javascript
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
js实现省级联动(数据结构优化)
2020/07/17 Javascript
vue中重定向redirect:‘/index‘,不显示问题、跳转出错的完美解决
2020/09/28 Javascript
js实现验证码干扰(动态)
2021/02/23 Javascript
[01:11:32]VG vs FNATIC 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
python获取豆瓣电影简介代码分享
2014/01/16 Python
python类和函数中使用静态变量的方法
2015/05/09 Python
在win和Linux系统中python命令行运行的不同
2016/07/03 Python
基于Python实现对PDF文件的OCR识别
2016/08/05 Python
pthon贪吃蛇游戏详细代码
2019/01/27 Python
在Python中获取操作系统的进程信息
2019/08/27 Python
python实现布隆过滤器及原理解析
2019/12/08 Python
Django User 模块之 AbstractUser 扩展详解
2020/03/11 Python
Html5新增标签与样式及让元素水平垂直居中
2019/07/11 HTML / CSS
HTML5 标准将把互联网视频扔回到黑暗时代
2010/02/10 HTML / CSS
StubHub美国:购买或出售您的门票
2019/07/09 全球购物
大四学生找工作的自荐信
2014/03/27 职场文书
银行纠风工作实施方案
2014/06/08 职场文书
四风个人对照检查材料思想汇报
2014/09/25 职场文书
教师作风整顿个人剖析材料
2014/10/10 职场文书
教师个人考察材料
2014/12/16 职场文书
2015年中秋节演讲稿
2015/03/20 职场文书
个人廉政承诺书
2015/04/28 职场文书
SONY AN-LP1 短波有源天线放大器
2021/04/22 无线电
Mysql 8.x 创建用户以及授予权限的操作记录
2022/04/18 MySQL
CSS SandBox应用场景及常见问题
2022/06/25 HTML / CSS