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


Posted in Javascript onAugust 23, 2017

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

  } 
});

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
『jQuery』名称冲突使用noConflict方法解决
Apr 22 Javascript
jQuery中nextAll()方法用法实例
Jan 07 Javascript
AngularJS 中使用Swiper制作滚动图不能滑动的解决方法
Nov 15 Javascript
JavaScript设置名字输入不合法的实现方法
May 23 Javascript
基于javaScript的this指向总结
Jul 22 Javascript
Node.js使用Express.Router的方法
Nov 14 Javascript
详解create-react-app 自定义 eslint 配置
Jun 07 Javascript
JavaScript实现简单的弹窗效果
May 19 Javascript
js实现验证码功能
Jul 24 Javascript
使用Vue-scroller页面input框不能触发滑动的问题及解决方法
Aug 08 Javascript
JavaScript数组类型Array相关的属性与方法详解
Sep 08 Javascript
使用Ajax实现进度条的绘制
Apr 07 Javascript
JavaScript实现的数字与字符串转换功能示例
Aug 23 #Javascript
最基础的vue.js双向绑定操作
Aug 23 #Javascript
vue组件实现文字居中对齐的方法
Aug 23 #Javascript
React+react-dropzone+node.js实现图片上传的示例代码
Aug 23 #Javascript
深入理解React中何时使用箭头函数
Aug 23 #Javascript
自定义类似于jQuery UI Selectable 的Vue指令v-selectable
Aug 23 #jQuery
JS数组交集、并集、差集的示例代码
Aug 23 #Javascript
You might like
PHP整数取余返回负数的相关解决方法
2014/05/15 PHP
php CI框架插入一条或多条sql记录示例
2014/07/29 PHP
php通过array_push()函数添加多个变量到数组末尾的方法
2015/03/18 PHP
PHP判断是否为空的几个函数对比
2015/04/21 PHP
Fleaphp常见函数功能与用法示例
2016/11/15 PHP
基于php双引号中访问数组元素报错的解决方法
2018/02/01 PHP
javascript fullscreen全屏实现代码
2009/04/09 Javascript
Extjs在exlipse中设置自动提示的方法
2010/04/07 Javascript
jquery 页眉单行信息滚动显示实现思路及代码
2014/06/26 Javascript
javascript数组去重方法汇总
2015/04/23 Javascript
js图片跟随鼠标移动代码
2015/11/26 Javascript
论Bootstrap3和Foundation5网格系统的异同
2016/05/16 Javascript
jquery实现input框获取焦点的方法
2017/02/06 Javascript
layui 对弹窗 form表单赋值的实现方法
2019/09/04 Javascript
微信头像地址失效踩坑记附带解决方案
2019/09/23 Javascript
对Layer弹窗使用及返回数据接收的实例详解
2019/09/26 Javascript
详解小程序如何动态绑定点击的执行方法
2019/11/26 Javascript
js构造函数constructor和原型prototype原理与用法实例分析
2020/03/02 Javascript
vue实现表单未编辑或未保存离开弹窗提示功能
2020/04/08 Javascript
vant 中van-list的用法说明
2020/11/11 Javascript
python多线程threading.Lock锁用法实例
2014/11/01 Python
使用Python制作微信跳一跳辅助
2018/01/31 Python
Jupyter中直接显示Matplotlib的图形方法
2018/05/24 Python
解决python3 urllib 链接中有中文的问题
2018/07/16 Python
python自动化测试之如何解析excel文件
2019/06/27 Python
python实现按行分割文件
2019/07/22 Python
tensorflow 2.1.0 安装与实战教程(CASIA FACE v5)
2020/06/30 Python
html5应用缓存_动力节点Java学院整理
2017/07/13 HTML / CSS
英国在线照明超市:Castlegate Lights
2019/10/30 全球购物
人事行政主管岗位职责
2013/12/22 职场文书
家长会标语
2014/06/24 职场文书
中学生社区服务活动报告
2015/02/05 职场文书
结婚老公保证书
2015/02/26 职场文书
职场中的你,辞职信写对了吗?
2019/06/26 职场文书
三年级作文之趣事作文
2019/11/04 职场文书
HTML基础详解(上)
2021/10/16 HTML / CSS