AngularJS指令与指令之间的交互功能示例


Posted in Javascript onDecember 14, 2016

本文实例讲述了AngularJS指令与指令之间的交互功能。分享给大家供大家参考,具体如下:

前面一篇文章《AngularJS指令与控制器之间的交互功能示例》我们了解了指令与控制器之间的交互,接下来看看指令与指令之间是如何进行交互的。

1.首先来了解一下什么是独立scope

为了更好的理解独立scope,我们来看一段代码:

<div ng-controller="myController1">
    <hello></hello>
    <hello></hello>
</div>
var app=angular.module('firstApp',[]);//app模块名
  app.controller('myController1',['$scope',function($scope){
}]);
app.directive('hello',function(){
    return{
      restrict:'E',
      template:"<div><input type='text' ng-  model='username'/>{{username}}",
      replace:true
    }
})

我们定义了一个指令,并在html中调用了两次,我们发现,调用两次的结果为:使用同一个指令构建的scope共享了一个数据,结果如下,我们在一个输入框中输入数据,会改变第二个指令中的输入框

AngularJS指令与指令之间的交互功能示例

如何解决这个问题呢,我们需要给指令生成独立的scope,每次使用指令时,生成的scope都是独立的,我们只需要如此修改:

app.directive('hello',function(){
    return{
      restrict:'E',
      scope:{},
      template:"<div><input type='text' ng-model='username'/>{{username}}",
      replace:true
    }
})

结果如下:

AngularJS指令与指令之间的交互功能示例

2.指令与指令之间的交互,指令的继承

(1)首先我们定义了一个父指令,定义的方式如下:

app.directive('father',function(){
    return{
     restrict:'E',
     scope:{},
     controller:function($scope){
      this.mean1=function(){
       console.log('这是第一个方法....');
      };
      this.mean2=function(){
       console.log('这是第二个方法....');
      };
      this.mean3=function(){
       console.log('这是第三个方法....');
      }
     }
    }
});

我们注意到,指令里面也有controller,这里的controller与控制器定义过程中的不同,这里的controller指的是指令的独立scope中定义的一些方法。

(2)定义子指令,子指令中可以使用父指令中scope中的方法:

app.directive('childFirst',function(){
    require:'^father',
    link:function(scope,ele,attr,fatherCtrl){
      fatherCtrl.mean1();
    }
})

这样通过:

require:'^father'

子指令就可以继承并且使用父指令中,独立scope中的一些方法。此时我们的link函数就可以有第四个参数。

link和controller中方法的区别:

link中的方法是需要执行或者马上要执行的方法。

controller中的方法是希望暴露出来,给外部使用的一些方法。

总结:

指令之间的交互,是通过指令的controller中暴露出来的方法,给外部指令使用。

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
js 无提示关闭浏览器页面的代码
Mar 09 Javascript
js/jQuery对象互转(快速操作dom元素)
Feb 04 Javascript
jQuery自动切换/点击切换选项卡效果的小例子
Aug 12 Javascript
jquery实现瀑布流效果分享
Mar 26 Javascript
jQuery动态产生select option下拉列表
Mar 15 Javascript
bootstrap table服务端实现分页效果
Aug 10 Javascript
axios拦截设置和错误处理方法
Mar 05 Javascript
Redux实现组合计数器的示例代码
Jul 04 Javascript
vue-cli 3.x 修改dist路径的方法
Sep 19 Javascript
Vue数据双向绑定的深入探究
Nov 27 Javascript
javascript原型链学习记录之继承实现方式分析
May 01 Javascript
Layer组件多个iframe弹出层打开与关闭及参数传递的方法
Sep 25 Javascript
AngularJS指令与控制器之间的交互功能示例
Dec 14 #Javascript
网站申请不到支付宝接口、微信接口,免接口收款实现方式几种解决办法
Dec 14 #Javascript
AngularJS定时器的使用与移除操作方法【interval与timeout】
Dec 14 #Javascript
本地Bootstrap文件字体图标引入却无法显示问题的解决方法
Apr 18 #Javascript
微信小程序中使元素占满整个屏幕高度实现方法
Dec 14 #Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
Dec 14 #Javascript
bootstrap modal弹出框的垂直居中
Dec 14 #Javascript
You might like
模拟xcopy的函数
2006/10/09 PHP
eAccelerator的安装与使用详解
2013/06/13 PHP
如何取得中文字符串中出现次数最多的子串
2013/08/08 PHP
php提示Failed to write session data错误的解决方法
2014/12/17 PHP
php+ajax简单实现全选删除的方法
2016/12/06 PHP
PHP实现针对日期,月数,天数,周数,小时,分,秒等的加减运算示例【基于strtotime】
2017/04/19 PHP
用JAVASCRIPT如何给&amp;lt;textarea&amp;gt;&amp;lt;/textarea&amp;gt;赋值
2007/04/20 Javascript
JS 获取span标签中的值的代码 支持ie与firefox
2009/08/24 Javascript
jQuery 源码分析笔记(4) Ready函数
2011/06/02 Javascript
js 利用className得到对象的实现代码
2011/11/15 Javascript
jQuery版仿Path菜单效果
2011/12/15 Javascript
jQuery实现tag便签去重效果的方法
2015/01/20 Javascript
jQuery头像裁剪工具jcrop用法实例(附演示与demo源码下载)
2016/01/22 Javascript
JavaScript学习总结之JS、AJAX应用
2016/01/29 Javascript
微信小程序 跳转传递数据的实例
2017/07/06 Javascript
vue--vuex详解
2019/04/15 Javascript
vue中node_modules中第三方模块的修改使用详解
2019/05/31 Javascript
JS实现继承的几种常用方式示例
2019/06/22 Javascript
vue 使用axios 数据请求第三方插件的使用教程详解
2019/07/05 Javascript
[02:03]完美世界DOTA2联赛10月30日赛事集锦
2020/10/31 DOTA
python使用pil进行图像处理(等比例压缩、裁剪)实例代码
2017/12/11 Python
python自动化测试之DDT数据驱动的实现代码
2019/07/23 Python
keras 特征图可视化实例(中间层)
2020/01/24 Python
Vision Direct比利时:在线订购隐形眼镜
2019/08/27 全球购物
美国家居装饰网上商店:Lulu & Georgia
2019/09/14 全球购物
怎样声明子类
2013/07/02 面试题
董事长职责范文
2013/11/08 职场文书
创建无烟单位实施方案
2014/03/29 职场文书
党课培训主持词
2014/04/01 职场文书
拓展训练激励口号
2014/06/17 职场文书
山东省召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
新员工试用期自我评价
2015/03/10 职场文书
2015年十一国庆节演讲稿
2015/03/20 职场文书
节水宣传标语口号
2015/12/26 职场文书
九不准学习心得体会
2016/01/23 职场文书
win10电脑关机快捷键是哪个 win10快速关机的几种方法
2022/08/14 数码科技