独立作用域:就是在指令中设置了scope: ****

·false 共享父作用域 
·true 继承父作用域,并且新建独立作用域 
·object 不继承父作用域,创建新的独立作用域

一般来说我们会使用第三种方式:为了避免同一父级作用域下,多个指令的相互污染。

在指令中设置了独立作用域之后,就会用三种方式与外界进行交互:@,=,&

1)@

这种使用方式一般使用与指令内部的作用,例如外部的控制器中定义了一个变量,这个变量只能由控制器自己进行修改,指令只能被动接受,此时就是用这种方式。
2)= 
这种方式一般用于双向绑定,例如外部控制器定义了一个变量,这个变量不仅控制器能进行修改,并且指令也能进行修改,两边数据交互统一,这个时候就使用这种绑定方式。

3)& 

这种方式一般是绑定函数,例如在指令内部想传递参数(必须以对象的形式)到外部控制器,并且能触发控制器的某方法。

指令使用场景:
<choice-item part-des = "['个人信息','职务信息','联系信息']" filter-click = 'filterClick({headConfig:headConfig})' ></choice-item>
指令中:
link: function($scope,el,attr) {
// 点击确认
$scope.filterClick({headConfig: $scope.emConfig});
} 
外部控制器:
$scope.filterClick = function(obj){
  $scope.headConfig = getSelectedConfig(obj.headConfig);
  $scope.filter_show = false;
};

 

版权声明:本文为evaling原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/evaling/p/9265202.html