当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > 详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用

详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用

2017年12月12日  | 移动技术网IT编程  | 我要评论

对于一个html5框架的好坏,我们有几个评判标准, 轻量级,可拓展,易复用,速度快。

对组件复用这点,angular以directive的形式展示给开发者,是一个还算不错的选择,作为一个ui组件,必定存在数据交互。

那么数据交互过程中的几个符号我们一定要有所了解,以及他们的区别是什么,防止我们在运用过程中出错。

1. 首先,我们看一scope作用域下面@的使用:

html

<!doctype html> 
<html ng-app='myapp'>  
 <head>   

 </head>  
 <body>    

 <div ng-controller="listctrl">   
  <input type="text" ng-model="t" /> 
   <test title="{{t}}" > 
    <span>我的angularjs</span> 
  </test> 
</div>  
<script type="text/javascript" src="angular.js"></script> 
<script type="text/javascript" src="main.js"></script> 
</body></html> 

js

var myapp=angular.module('myapp',[]); 
myapp.controller('listctrl',function($scope){ 
  $scope.logchore="motorola"; 
}); 


myapp.directive('test',function(){ 
  return { 
    'restrict':'e', 
    scope:{ 
      title:"@" 
    }, 
    template:'<div >{{title}}</div>' 

  } 
}); 

这个必须指定的,这里的title是指令里scope的@对应的,t就是控制域scope下的 .

2. = 的使用。

html

<!doctype html> 
<html ng-app='myapp'>  
 <head>   

 </head>  
 <body>    

 <div ng-controller="listctrl">   
  <input type="text" ng-model="t" /> 
   <test title="t" > 
    <p>{{title}}</p> 
    <span>我的angularjs</span> 
  </test> 
</div>  
<script type="text/javascript" src="angular.js"></script> 
<script type="text/javascript" src="main05.js"></script> 
</body></html> 

js

var myapp=angular.module('myapp',[]); 
myapp.controller('listctrl',function($scope){ 
  $scope.logchore="motorola"; 
}); 


myapp.directive('test',function(){ 
  return { 
    'restrict':'e', 
    scope:{ 
      title:"=" 
    }, 
    template:'<div >{{title}}</div>' 

  } 
}); 

和上面@相比,这个直接赋值等于scope域下的t了

3. 最好我们看看&符号的使用

html

<!doctype html> 
<html ng-app='myapp'>  
 <head>   

 </head>  
 <body>    

 <div ng-controller="listctrl">   
   <test flavor="logchore()" ></test> 
</div>  
<script type="text/javascript" src="angular.js"></script> 
<script type="text/javascript" src="main05.js"></script> 
</body></html> 

js

var myapp=angular.module('myapp',[]); 
myapp.controller('listctrl',function($scope){ 
  $scope.logchore=function(){ 
    alert('ok'); 
  }; 
}); 


myapp.directive('test',function(){ 
  return { 
    'restrict':'e', 
    scope:{ 
      flavor:"&"  
    }, 
    template:'<div ><button ng-click="flavor()"></button></div>' 

  } 
}); 

尝试一下,就明白了,简洁明了!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网