AngularJS指令详解(3)—指令与指令之间的交互

上一节,我们了解了指令与控制器之间的交互,接下来看看指令与指令之间是如何进行交互的。

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共享了一个数据,结果如下,我们在一个输入框中输入数据,会改变第二个指令中的输入框
这里写图片描述

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

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

结果如下:
这里写图片描述

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中暴露出来的方法,给外部指令使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值