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 相关文章推荐
javascript 拖放效果实现代码
Jan 22 Javascript
让人期待的2011年度最佳 jQuery 插件分享
Mar 16 Javascript
jQuery中$.click()无效问题分析
Jan 29 Javascript
javascript实现简单的二级联动
Mar 19 Javascript
Boostrap实现的登录界面实例代码
Oct 09 Javascript
用js控件div的滚动条,让它在内容更新时自动滚到底部的实现方法
Oct 27 Javascript
JS中用三种方式实现导航菜单中的二级下拉菜单
Oct 31 Javascript
BootStrap Fileinput的使用教程
Dec 30 Javascript
JavaScript基本类型值-Number类型
Feb 24 Javascript
vue.js 左侧二级菜单显示与隐藏切换的实例代码
May 23 Javascript
Angular中自定义Debounce Click指令防止重复点击
Jul 26 Javascript
jquery获取file表单选择文件的路径、名字、大小、类型
Jan 18 jQuery
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
PHP 图像尺寸调整代码
2010/05/26 PHP
CodeIgniter框架提示Disallowed Key Characters的解决办法
2014/04/21 PHP
PHP数组函数array_multisort()用法实例分析
2016/04/02 PHP
五段实用的js高级技巧
2011/12/20 Javascript
jQuery对下拉框,单选框,多选框的操作
2014/02/21 Javascript
基于jQuery实现文本框缩放以及上下移动功能
2014/11/24 Javascript
javascript中对Date类型的常用操作小结
2016/05/19 Javascript
jQuery checkbox选中问题之prop与attr注意点分析
2016/11/15 Javascript
关于Vue.js一些问题和思考学习笔记(1)
2016/12/02 Javascript
Jquery根据浏览器窗口改变调整大小的方法
2017/02/07 Javascript
node vue项目开发之前后端分离实战记录
2017/12/13 Javascript
用最少的JS代码写出贪吃蛇游戏
2018/01/12 Javascript
vue打包的时候自动将px转成rem的操作方法
2018/06/20 Javascript
Vue render渲染时间戳转时间,时间转时间戳及渲染进度条效果
2018/07/27 Javascript
vue-cli 首屏加载优化问题
2018/11/06 Javascript
element表格翻页第2页从1开始编号(后端从0开始分页)
2019/12/10 Javascript
Vue Object 的变化侦测实现代码
2020/04/15 Javascript
vue监听dom大小改变案例
2020/07/29 Javascript
Vue解决echart在element的tab切换时显示不正确问题
2020/08/03 Javascript
详解Python装饰器由浅入深
2016/12/09 Python
详解Python map函数及Python map()函数的用法
2017/11/16 Python
CSS3 绘制BMW logo实的现代码
2013/04/25 HTML / CSS
英国时尚家具、家居饰品及礼品商店:Graham & Green
2016/09/15 全球购物
Dogeared官网:在美国手工制作的珠宝
2019/08/24 全球购物
Three Graces London官网:英国奢侈品牌
2021/03/18 全球购物
C#基础面试题
2016/10/17 面试题
保安员岗位职责
2013/11/17 职场文书
职业生涯规划设计步骤
2014/01/12 职场文书
学校安全工作制度
2014/01/19 职场文书
应届护士求职信范文
2014/01/26 职场文书
药品业务员岗位职责
2014/04/17 职场文书
我们的节日清明节活动总结
2014/04/30 职场文书
室内设计专业毕业生求职信
2014/05/02 职场文书
2014年四风个人对照检查及整改措施
2014/10/28 职场文书
民警忠诚教育心得体会
2016/01/23 职场文书
Win11 Beta 预览版 22621.575 和 22622.575更新补丁KB5016694发布(附更新内容大全)
2022/08/14 数码科技