首页 > 编程 > JavaScript > 正文

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

2019-11-19 15:42:05
字体:
来源:转载
供稿:网友

对于一个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>'   } }); 

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

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表