详解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 相关文章推荐
10个基于Jquery的幻灯片插件教程
Oct 29 Javascript
jQuery Mobile的loading对话框显示/隐藏方法分享
Nov 26 Javascript
深入解析JavaScript中的变量作用域
Dec 06 Javascript
jquery.hotkeys监听键盘按下事件keydown插件
May 11 Javascript
js点击选择文本的方法
Feb 09 Javascript
避免jQuery名字冲突 noConflict()方法
Jul 30 Javascript
js模式化窗口问题![window.dialogArguments]
Oct 30 Javascript
js 模仿锚点定位的实现方法
Nov 19 Javascript
利用PM2部署node.js项目的方法教程
May 10 Javascript
Django中使用jquery的ajax进行数据交互的实例代码
Oct 15 jQuery
JavaScript笛卡尔积超简单实现算法示例
Jul 30 Javascript
vue-cli3 配置开发与测试环境详解
May 17 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迭代器实现斐波纳契数列的函数
2013/11/12 PHP
laravel实现批量更新多条记录的方法示例
2017/10/22 PHP
jquery的Theme和Theme Switcher使用小结
2010/09/08 Javascript
js自定义方法通过隐藏iframe实现文件下载
2013/02/21 Javascript
js之onload事件的一点使用心得
2013/08/14 Javascript
JS 实现点击a标签的时候让其背景更换
2013/10/15 Javascript
从数组中随机取x条不重复数据的JS代码
2013/12/24 Javascript
JavaScript获取客户端计算机硬件及系统等信息的方法
2014/01/02 Javascript
js中window.open()的所有参数详细解析
2014/01/09 Javascript
基于JavaScript实现弹出框效果
2016/02/19 Javascript
解决JS组件bootstrap table分页实现过程中遇到的问题
2016/04/21 Javascript
javascript实现不同颜色Tab标签切换效果
2016/04/27 Javascript
总结JavaScript设计模式编程中的享元模式使用
2016/05/21 Javascript
AngularJS教程之MVC体系结构详解
2016/08/16 Javascript
JavaScript的继承实现小结
2017/05/07 Javascript
详解AngularJS 模块化
2017/06/14 Javascript
JavaScript创建对象的七种方式全面总结
2017/08/21 Javascript
轻松玩转BootstrapTable(后端使用SpringMVC+Hibernate)
2017/09/06 Javascript
简单谈谈js的数据类型
2017/09/25 Javascript
vue实现双向绑定和依赖收集遇到的坑
2018/11/29 Javascript
Easyui 关闭jquery-easui tab标签页前触发事件的解决方法
2019/04/28 jQuery
微信小程序iBeacon测距及稳定程序的实现解析
2019/07/31 Javascript
微信小程序scroll-view的滚动条设置实现
2020/03/02 Javascript
解决vue单页面应用打包后相对路径、绝对路径相关问题
2020/08/14 Javascript
js实现限定范围拖拽的示例
2020/10/26 Javascript
用Python脚本生成Android SALT扰码的方法
2013/09/18 Python
python计算文本文件行数的方法
2015/07/06 Python
python根据文本生成词云图代码实例
2019/11/15 Python
python梯度下降算法的实现
2020/02/24 Python
详解pycharm配置python解释器的问题
2020/10/15 Python
python 调整图片亮度的示例
2020/12/03 Python
世界上最大的餐具公司:Oneida
2016/12/17 全球购物
博士生入学考试推荐信
2013/11/17 职场文书
大学生就业意向书
2015/05/11 职场文书
2015年基层党建工作总结
2015/05/14 职场文书
python实现局部图像放大
2021/11/17 Python