详解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判断用户浏览器是否是XP SP2的IE6
Mar 08 Javascript
超棒的javascript页面顶部卷动广告效果
Dec 01 Javascript
jQuery 选择器项目实例分析及实现代码
Dec 28 Javascript
js文本框输入点回车触发确定兼容IE、FF等
Nov 19 Javascript
原生js和jQuery写的网页选项卡特效对比
Apr 27 Javascript
Ajax实现不刷新取最新商品
Mar 01 Javascript
jQuery实现拖动效果的实例代码
Jun 25 jQuery
js实现一个简单的MVVM框架示例
Jan 15 Javascript
解决vue-cli单页面手机应用input点击手机端虚拟键盘弹出盖住input问题
Aug 25 Javascript
es6函数之尾递归用法实例分析
Apr 25 Javascript
vue相同路由跳转强制刷新该路由组件操作
Aug 05 Javascript
JavaScript实现一键复制内容剪贴板
Jul 23 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
php使用parse_str实现查询字符串解析到变量中的方法
2017/02/17 PHP
jquery $.ajax入门应用一
2008/11/19 Javascript
Javascript String.replace的妙用
2009/09/08 Javascript
javascript学习笔记(十三) js闭包介绍(转)
2012/06/20 Javascript
js获取指定日期前后的日期代码
2013/08/20 Javascript
返回页面顶部top按钮通过锚点实现(自写)
2013/08/30 Javascript
15个jquery常用方法、小技巧分享
2015/01/13 Javascript
javascript事件委托的方式绑定详解
2015/06/10 Javascript
写给小白的JavaScript引擎指南
2015/12/04 Javascript
JSON遍历方式实例总结
2015/12/07 Javascript
JavaScript实现显示函数调用堆栈的方法
2016/04/21 Javascript
JavaScript中的原型prototype完全解析
2016/05/10 Javascript
javascript实现起伏的水波背景效果
2016/05/16 Javascript
基于jQuery的select下拉框选择触发事件实例分析
2016/11/18 Javascript
jQuery实现联动下拉列表查询框
2017/01/04 Javascript
微信小程序与php 实现微信支付的简单实例
2017/06/23 Javascript
详解Vue中的基本语法和常用指令
2019/07/23 Javascript
VUE 实现动态给对象增加属性,并触发视图更新操作示例
2019/11/29 Javascript
nodejs对mongodb数据库的增加修删该查实例代码
2020/01/05 NodeJs
在Django的视图(View)外使用Session的方法
2015/07/23 Python
浅谈django中的认证与登录
2016/10/31 Python
Python3.5.3下配置opencv3.2.0的操作方法
2018/04/02 Python
pandas DataFrame 行列索引及值的获取的方法
2019/07/02 Python
scrapy处理python爬虫调度详解
2020/11/23 Python
Python .py生成.pyd文件并打包.exe 的注意事项说明
2021/03/04 Python
canvas基础之图形验证码的示例
2018/01/02 HTML / CSS
StubHub智利:购买和出售您的门票
2016/11/23 全球购物
澳大利亚相机之家:Camera House
2017/11/30 全球购物
JAVA代码查错题
2014/10/10 面试题
经济管理专业自荐信
2013/12/30 职场文书
2014春晚主持词
2014/03/25 职场文书
用电申请报告范文
2015/05/18 职场文书
经济纠纷起诉状
2015/05/20 职场文书
我的1919观后感
2015/06/03 职场文书
2016优秀护士求职自荐信
2016/01/28 职场文书
超详细Python解释器新手安装教程
2021/05/10 Python