详解angularJS自定义指令间的相互交互


Posted in Javascript onJuly 05, 2017

AngularJS 自定义指令

transclude:当元素标签需要嵌套时使用,与ng-transclude配合使用。默认值为false不能使用嵌套,true为可以使用嵌套。在哪个标签上使用ng-transclude就在哪个标签内进行嵌套。

代码示例:(将hello、hi标签进行替换同时span标签嵌套div内)

<script type="text/javascript">
  var m = angular.module('myApp',[]);
  m.directive('hello',function(){
    return{
      restrict:'E',
      replace:true,
      transclude:true,
      template:'<div>hello angular<h1 ng-transclude></h1></div>'
    };
  });
  m.directive('hi',function(){
    return{
      restrict:'E',
      replace:true,
      template:'<span>hi angular</span>'
    };
  });
  m.controller('Aaa',['$scope',function($scope){
    $scope.name='hello';
  }]);
  </script>

<body ng-controller="Aaa">
  <hello>
    <hi></hi>
  </hello>
</body>

页面结果展示:

详解angularJS自定义指令间的相互交互

在自定义指令当中controller与link的区别:

link是指DOM操作,操作也是针对当前标签

controller是多调用性的数据共享,指令与指令间进行交互时也可以设置一些方法数据,在其他标签中也可以调用

require:从外部引入数据,参数为被引入的指令,被引入的指令需要在引入指令的身上。

》^:是指被引入的指令是引入指令的父级

》?:兼容错误

代码示例:

<script type="text/javascript">
  var m = angular.module('myApp',[]);
  m.directive('hello',function(){
    return{
      restrict:'E',
      replace:true,
      transclude:true,
      controller:function($scope){
        //$scope.name='miaov';只能在该标签中使用
        this.name = 'miaov';//可以在其他标签中调用
      },
      template:'<div>hello angular<h1 ng-transclude></h1></div>'
    };
  });
  m.directive('hi',function(){
    return{
      restrict:'E',
      replace:true,
      require:'?^hello',//从外部引入指令,参数为被引入的标签
      link:function($scope,element,attr,reController){
        console.log(reController.name);
      },
      template:'<span>hi angular</span>'
    };
  });
  m.controller('Aaa',['$scope',function($scope){
    $scope.name='hello';
  }]);
  </script>

<body ng-controller="Aaa">
  <hello>
    <hi></hi>
  </hello>
</body>

页面结果展示:

详解angularJS自定义指令间的相互交互

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 发个判断字符串是否为符合标准的函数
Apr 27 Javascript
dojo学习第二天 ajax异步请求之绑定列表
Aug 29 Javascript
Javascript验证Visa和MasterCard信用卡号的方法
Jul 27 Javascript
JavaScript+canvas实现七色板效果实例
Feb 18 Javascript
利用angular.copy取消变量的双向绑定与解析
Nov 25 Javascript
servlet+jquery实现文件上传进度条示例代码
Jan 25 Javascript
React组件中的this的具体使用
Feb 28 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
Aug 20 Javascript
JS拖动选择table里的单元格完整实例【基于jQuery】
May 28 jQuery
JS Math对象与Math方法实例小结
Jul 05 Javascript
创建nuxt.js项目流程图解
Mar 13 Javascript
js实现限定区域范围拖拉拽效果
Nov 20 Javascript
利用canvas实现的加载动画效果实例代码
Jul 05 #Javascript
AngularJS使用ocLazyLoad实现js延迟加载
Jul 05 #Javascript
vue一步步实现alert功能
Jul 05 #Javascript
详解vue.js移动端导航navigationbar的封装
Jul 05 #Javascript
JS实现移动端按首字母检索城市列表附源码下载
Jul 05 #Javascript
webpack教程之webpack.config.js配置文件
Jul 05 #Javascript
webstorm添加vue.js支持的方法教程
Jul 05 #Javascript
You might like
如何提高MYSQL数据库的查询统计速度 select 索引应用
2007/04/11 PHP
zf框架的session会话周期及次数限制使用示例
2014/03/13 PHP
Yii获取当前url和域名的方法
2015/06/08 PHP
PHP自动识别当前使用移动终端
2018/05/21 PHP
PHP中mysqli_get_server_version()的实例用法
2020/02/03 PHP
TNC vs RR BO3 第一场 2.14
2021/03/10 DOTA
jQuery学习笔记之DOM对象和jQuery对象
2010/12/22 Javascript
javascript数字数组去重复项的实现代码
2010/12/30 Javascript
解决js数据包含加号+通过ajax传到后台时出现连接错误
2013/08/01 Javascript
js获取多个tagname的节点数组
2013/09/22 Javascript
jquery图片播放浏览插件prettyPhoto使用详解
2014/12/19 Javascript
js下拉选择框与输入框联动实现添加选中值到输入框的方法
2015/08/17 Javascript
JavaScript实现网页加载进度条代码超简单
2015/09/21 Javascript
Bootstrap每天必学之导航条(二)
2016/03/01 Javascript
AngularJS入门教程之AngularJS 模板
2016/08/18 Javascript
js事件源window.event.srcElement兼容性写法(详解)
2016/11/25 Javascript
Javascript 高性能之递归,迭代,查表法详解及实例
2017/01/08 Javascript
JavaScript生成指定范围随机数和随机序列的方法
2018/05/05 Javascript
浅谈一种让小程序支持JSX语法的新思路
2019/06/16 Javascript
详解BootStrap表单验证中重置BootStrap-select验证提示不清除的坑
2019/09/17 Javascript
[36:17]DOTA2上海特级锦标赛 - VGL音乐会全集
2016/03/06 DOTA
Python设计实现的计算器功能完整实例
2017/08/18 Python
Django数据库操作的实例(增删改查)
2017/09/04 Python
Python爬取个人微信朋友信息操作示例
2018/08/03 Python
Python Django简单实现session登录注销过程详解
2019/08/06 Python
python运用sklearn实现KNN分类算法
2019/10/16 Python
keras导入weights方式
2020/06/12 Python
Python matplotlib读取excel数据并用for循环画多个子图subplot操作
2020/07/14 Python
C#如何调用Word并打开一个Word文档
2013/05/08 面试题
测控技术与仪器个人求职信范文
2013/12/30 职场文书
心理健康日活动总结
2014/05/08 职场文书
大雁塔英文导游词
2015/02/10 职场文书
2015年师德师风自我评价范文
2015/03/05 职场文书
《曹冲称象》教学反思
2016/02/20 职场文书
解决mysql问题:由于找不到MSVCR120.dll,无法继续执行代码
2021/06/26 MySQL
Android学习之BottomSheetDialog组件的使用
2022/06/21 Java/Android