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分页控件 可用于无刷新分页
Jul 23 Javascript
动态改变div的z-index属性的简单实例
Aug 08 Javascript
jquery实现input输入框实时输入触发事件代码
Jan 28 Javascript
jquery插件NProgress.js制作网页加载进度条
Jun 05 Javascript
微信小程序去哪里找 小程序到底如何使用(附小程序名单)
Jan 09 Javascript
JS 实现分页打印功能
May 16 Javascript
linux 后台运行node服务指令方法
May 23 Javascript
React+Webpack快速上手指南(小结)
Aug 15 Javascript
Vue中的$set的使用实例代码
Oct 08 Javascript
vue+iview 兼容IE11浏览器的实现方法
Jan 07 Javascript
ES6 迭代器与可迭代对象的实现
Feb 11 Javascript
Openlayers学习之地图比例尺控件
Sep 28 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
全国FM电台频率大全 - 17 湖北省
2020/03/11 无线电
深入PHP异步执行的详解
2013/06/03 PHP
php实现的漂亮分页方法
2014/04/17 PHP
php自定义apk安装包实例
2014/10/20 PHP
获取客户端电脑日期时间js代码(jquery)
2012/09/12 Javascript
JS编程小常识很有用
2012/11/26 Javascript
使图片旋转的3种解决方案
2013/11/21 Javascript
JS两种定义方式的区别、内部原理
2013/11/21 Javascript
js实现跨域访问的三种方法
2015/12/09 Javascript
AngularJS入门教程之Scope(作用域)
2016/07/27 Javascript
微信小程序  modal弹框组件详解
2016/10/27 Javascript
Vue 父子组件、组件间通信
2017/03/08 Javascript
使用iView Upload 组件实现手动上传图片的示例代码
2018/10/01 Javascript
JavaScript简易计算器制作
2020/01/17 Javascript
浅谈实现在线预览PDF的几种解决办法
2020/08/10 Javascript
[01:00:52]2018DOTA2亚洲邀请赛 4.4 淘汰赛 EG vs LGD 第一场
2018/04/05 DOTA
[03:02]2020完美世界城市挑战赛(秋季赛)总决赛回顾
2021/03/11 DOTA
更改Ubuntu默认python版本的两种方法python-&gt; Anaconda
2016/12/18 Python
Python利用matplotlib.pyplot绘图时如何设置坐标轴刻度
2018/04/09 Python
详解Python3中的迭代器和生成器及其区别
2018/10/09 Python
pandas分区间,算频率的实例
2019/07/04 Python
python实现日志按天分割
2019/07/22 Python
DJango的创建和使用详解(默认数据库sqlite3)
2019/11/18 Python
pandas数据处理之绘图的实现
2020/06/15 Python
Python random模块的使用示例
2020/10/10 Python
HTML5之web workers_动力节点Java学院整理
2017/07/17 HTML / CSS
使用SVG实现提示框功能的示例代码
2020/06/05 HTML / CSS
超30万乐谱下载:Musicnotes.com
2016/09/24 全球购物
J2EE系统只能是基于web
2015/09/08 面试题
《台湾的蝴蝶谷》教学反思
2014/02/20 职场文书
出生公证书样本
2014/04/04 职场文书
优秀学生干部先进事迹材料
2014/05/26 职场文书
外出听课学习心得体会
2016/01/15 职场文书
2016银行招聘自荐信
2016/01/28 职场文书
管理者们如何制定2019年的工作计划?
2019/07/01 职场文书
导游词之山东八仙过海景区
2019/11/11 职场文书