详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
程序员文章站
2022-07-06 21:16:44
对于一个html5框架的好坏,我们有几个评判标准, 轻量级,可拓展,易复用,速度快。
对组件复用这点,angular以directive的形式展示给开发者,是一个还算不错...
对于一个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>' } });
尝试一下,就明白了,简洁明了!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
MySQL中datetime和timestamp的区别及使用详解
-
详解Django 中是否使用时区的区别
-
PHP中register_globals参数为OFF和ON的区别(register_globals 使用详解)
-
Linux命令中Ctrl+z、Ctrl+c和Ctrl+d的区别和使用详解
-
JavaScript中的this,call,apply使用及区别详解
-
linux中各种锁机制的使用与区别详解
-
php中const与define的使用区别 详解
-
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
-
python中urllib.request和requests的使用及区别详解
-
bindParam和bindValue的区别以及在Yii2中的使用详解