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 相关文章推荐
超强的IE背景图片闪烁(抖动)的解决办法
Sep 09 Javascript
语义化 H1 标签
Jan 14 Javascript
js简单实现删除记录时的提示效果
Dec 05 Javascript
js定时器的使用(实例讲解)
Jan 06 Javascript
javascript定时器完整实例
Feb 10 Javascript
JavaScript学习笔记之数组去重
Mar 23 Javascript
基于HTML+CSS+JS实现增加删除修改tab导航特效代码
Aug 05 Javascript
Angular2  NgModule 模块详解
Oct 19 Javascript
JavaScript实现经典排序算法之冒泡排序
Dec 28 Javascript
Vue.js分页组件实现:diVuePagination的使用详解
Jan 10 Javascript
vue.js实现只弹一次弹框
Jan 29 Javascript
webuploader分片上传的实现代码(前后端分离)
Sep 10 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
用文本文件制作留言板提示(下)
2006/10/09 PHP
Warning: session_destroy() : Trying to destroy uninitialized sessionq错误
2011/06/16 PHP
php实现改变图片直接打开为下载的方法
2015/04/14 PHP
修复ShopNC使用QQ 互联时提示100010 错误
2015/11/08 PHP
PHP中16个高危函数整理
2019/09/19 PHP
php实现对文件压缩简单的方法
2019/09/29 PHP
Yii中特殊行为ActionFilter的使用方法示例
2020/10/18 PHP
Javascript操作select方法大全[新增、修改、删除、选中、清空、判断存在等]
2008/09/26 Javascript
JavaScript DOM学习第六章 表单实例
2010/02/19 Javascript
基于jQuery的图片大小自动适应实现代码
2010/11/17 Javascript
Jquery 模板数据绑定插件的使用方法详解
2013/07/08 Javascript
Javascript Web Slider 焦点图示例源码
2013/10/10 Javascript
js如何判断用户是在PC端和还是移动端访问
2014/04/24 Javascript
使用JSON.parse将json字符串转换成json对象的时候会出错
2014/09/04 Javascript
Bootstrap编写一个兼容主流浏览器的受众门户式风格页面
2016/07/01 Javascript
微信开发 JS-SDK 6.0.2 经常遇到问题总结
2016/12/08 Javascript
vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
2017/03/06 Javascript
JS运动特效之完美运动框架实例分析
2018/01/24 Javascript
AngularJS对动态增加的DOM实现ng-keyup事件示例
2018/03/12 Javascript
浅谈Postman解决token传参的问题
2018/03/31 Javascript
[01:15:12]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#4Newbee VS CDEC
2016/03/03 DOTA
Python中为feedparser设置超时时间避免堵塞
2014/09/28 Python
在Python的Django框架中实现Hacker News的一些功能
2015/04/17 Python
Python 使用with上下文实现计时功能
2018/03/09 Python
完美解决Pycharm无法导入包的问题 Unresolved reference
2018/05/18 Python
python实现内存监控系统
2021/03/07 Python
Python运行异常管理解决方案
2020/03/09 Python
Python matplotlib可视化实例解析
2020/06/01 Python
PyQt5-QDateEdit的简单使用操作
2020/07/12 Python
CSS3的常见transformation图形变化用法小结
2016/05/13 HTML / CSS
调解员先进事迹材料
2014/02/07 职场文书
幼儿园感恩节活动方案2014
2014/10/11 职场文书
募捐感谢信
2015/01/22 职场文书
写作之关于描写老人的好段摘抄
2019/11/14 职场文书
AJAX学习笔记
2021/05/18 Javascript
Windows11 Insider Preview Build 25206今日发布 更新内容汇总
2022/09/23 数码科技