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 相关文章推荐
用javascript控制iframe滚动的代码
Apr 10 Javascript
告诉你什么是javascript的回调函数
Sep 04 Javascript
javascript实现的网站访问量统计代码
Dec 20 Javascript
AngularJS ng-bind-html 指令详解及实例代码
Jul 30 Javascript
详细分析Javascript中创建对象的四种方式
Aug 17 Javascript
JavaScript数据结构之二叉树的遍历算法示例
Apr 13 Javascript
深入理解vue.js中的v-if和v-show
Jun 22 Javascript
vue和react等项目中更简单的实现展开收起更多等效果示例
Feb 22 Javascript
JS装饰器函数用法总结
Apr 21 Javascript
详解Vue demo实现商品列表的展示
May 07 Javascript
ES6中的class是如何实现的(附Babel编译的ES5代码详解)
May 17 Javascript
Vue的生命周期一起来看看
Feb 24 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
php中判断文件空目录是否有读写权限的函数代码
2012/08/07 PHP
php遍历文件夹所有文件子文件夹函数代码
2013/11/27 PHP
PHP 面向对象程序设计(oop)学习笔记 (二) - 静态变量的属性和方法及延迟绑定
2014/06/12 PHP
php树型类实例
2014/12/05 PHP
Yii2.0 模态弹出框+ajax提交表单
2016/05/22 PHP
php+mysql查询实现无限下级分类树输出示例
2016/10/03 PHP
修复ie8&amp;chrome下window的resize事件多次执行
2011/10/20 Javascript
轻松学习jQuery插件EasyUI EasyUI创建CRUD应用
2015/11/30 Javascript
总结在前端排序中遇到的问题
2016/07/19 Javascript
使用JS读取XML文件的方法
2016/11/25 Javascript
BootStrap Table 获取同行不同列元素的方法
2016/12/19 Javascript
javascript 中的try catch应用总结
2017/04/01 Javascript
详解RequireJs官方使用教程
2017/10/31 Javascript
学习Vue组件实例
2018/04/28 Javascript
vuejs实现ready函数加载完之后执行某个函数的方法
2018/08/31 Javascript
vue-router命名视图的使用讲解
2019/01/19 Javascript
用Vue编写抽象组件的方法
2019/05/06 Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
2020/04/06 Javascript
python字符串的常用操作方法小结
2016/05/21 Python
Python 错误和异常代码详解
2018/01/29 Python
python3.5绘制随机漫步图
2018/08/27 Python
利用arcgis的python读取要素的X,Y方法
2018/12/22 Python
python的依赖管理的实现
2019/05/14 Python
Django如何实现密码错误报错提醒
2020/09/04 Python
比较基础的php面试题及答案-填空题
2014/04/26 面试题
给医务人员表扬信
2014/01/12 职场文书
小学绿色学校申报材料
2014/08/23 职场文书
2015年科普工作总结
2015/07/23 职场文书
2015大一新生军训感言
2015/08/01 职场文书
市场营销计划书
2019/04/24 职场文书
MySQL中IF()、IFNULL()、NULLIF()、ISNULL()函数的使用详解
2021/06/26 MySQL
python中出现invalid syntax报错的几种原因分析
2022/02/12 Python
Mysql数据库表中为什么有索引却没有提高查询速度
2022/02/24 MySQL
如何通过简单的代码描述Angular父组件、子组件传值
2022/04/07 Javascript
《游戏王:大师决斗》新活动上线 若无符合卡组可免费租用
2022/04/13 其他游戏
Hive常用日期格式转换语法
2022/06/25 数据库