angular指令的详细讲解,不断补充
独立作用域:就是在指令中设置了scope: ****
·false 共享父作用域 
·true 继承父作用域,并且新建独立作用域 
·object 不继承父作用域,创建新的独立作用域
一般来说我们会使用第三种方式:为了避免同一父级作用域下,多个指令的相互污染。
在指令中设置了独立作用域之后,就会用三种方式与外界进行交互:@,=,&
1)@
这种使用方式一般使用与指令内部的作用,例如外部的控制器中定义了一个变量,这个变量只能由控制器自己进行修改,指令只能被动接受,此时就是用这种方式。
但是这不是一种双向绑定,因此需要花括号。
<choice-item   sty-obj= "{{styObj}}"></choice-item>
2)= 
这种方式一般用于双向绑定,例如外部控制器定义了一个变量,这个变量不仅控制器能进行修改,并且指令也能进行修改,两边数据交互统一,这个时候就使用这种绑定方式。
这是一种双向绑定的方式意味着绑定的时候不需要花括号。
<choice-item html-config='htmlConfig' em-config='emConfig'></choice-item>
3)&
这种方式一般是绑定函数,例如在指令内部想传递参数(必须以对象的形式)到外部控制器,并且能触发控制器的某方法。
指令使用场景:
<choice-item part-des = "['个人信息','职务信息','联系信息']"
filter-click = 'filterClick({headConfig:headConfig})' ></choice-item>
指令中:
link: function($scope,el,attr) {
// 点击确认
$scope.filterClick({headConfig: $scope.emConfig});
}
外部控制器:
$scope.filterClick = function(obj){
$scope.headConfig = getSelectedConfig(obj.headConfig);
$scope.filter_show = false;
};
replace: 是一个可选参数,如果设置了这个参数,值必须为true,因为默认值为false。默认值意味着模板会被当作子元素插入到调用此指令的元素内部:
<my-directive></my-directive>
.directive("myDirective",function(){
return {
template:"<h3>世上无难事,只怕有心人</h3>"
}
}) 调用指令之后的结果如下(这是默认replace为false时的情况):
<my-directive>
<h3>世上无难事,只怕有心人</h3>
</my-directive>
如果replace被设置为了true:
.directive("myDirective",function(){
return {
replace:true,
template:"<h3>世上无难事,只怕有心人</h3>"
}
}) 那么指令调用后的结果将是:
<h3>世上无难事,只怕有心人</h3>
官方网址:
http://www.angularjs.net.cn/tutorial/5.html
angular指令的详细讲解,不断补充的更多相关文章
- C++语言堆栈的详细讲解
		
本文主要向大家介绍了C++语言堆栈的详细讲解,通过具体的内容向大家展示,希望对大家学习C++语言有所帮助. 一.预备知识—程序的内存分配 一个由c/C++编译的程序占用的内存分为以下几个部分 1.栈区 ...
 - 16汇编第十讲完结Call变为函数以及指令的最后讲解
		
16汇编完结Call变为函数以及指令的最后讲解 学了10天的16位汇编,这一讲就结束了,这里总结一下昨天的LOOP指令的缺陷,因为lOOP指令的缺陷,所以我们都改为下面的汇编代码使用了,自己去写,其中 ...
 - auth权限认证详细讲解
		
auth权限认证详细讲解 一.总结 一句话总结:四表两组关系,一个多对多(权限和用户组之间)(多对多需要3个表),一个一对多(用户和用户组之间) 1.实际上使用Auth是需要4张表的(1.会员表 2. ...
 - Siki_Unity_2-1_API常用方法和类详细讲解(下)
		
Unity 2-1 API常用方法和类详细讲解(下) 任务101&102:射线检测 射线origin + direction:射线检测:射线是否碰撞到物体 (物体需要有碰撞器),碰撞物体的信息 ...
 - Nginx基础详细讲解
		
Nginx基础详细讲解 链接:https://pan.baidu.com/s/1xB20bnuanh0Avs4kwRpSXQ 提取码:migq 复制这段内容后打开百度网盘手机App,操作更方便哦 1. ...
 - vue-cli 目录结构详细讲解
		
https://juejin.im/post/5c3599386fb9a049db7351a8 vue-cli 目录结构详细讲解 目录 结构预览 ├─build // 保存一些webpack的初始化配 ...
 - 30 道 Vue 面试题,内含详细讲解(涵盖入门到精通,自测 Vue 掌握程度)
		
前言 本文以前端面试官的角度出发,对 Vue 框架中一些重要的特性.框架的原理以问题的形式进行整理汇总,意在帮助作者及读者自测下 Vue 掌握的程度.本文章节结构以从易到难进行组织,建议读者按章节顺序 ...
 - head标签详细讲解
		
head标签详细讲解 head位于html网页的头部,后前的标签,并以开始以结束的一html标签. Head标签位置如图: head标签示意图 head包含标签 meta,title,link,bas ...
 - angular指令深度学习篇
		
angular指令深度学习-过滤器 limitTo ... <body ng-app="app" > <div ng-controller="myCtr ...
 
随机推荐
- 常用php操作redis命令整理(一)通用及字符串类型
			
Key相关操作 TYPE 类型检测,字符串返回string,列表返回 list,set表返回set/zset,hash表返回hash,key不存在返回0 <?php echo $redis-&g ...
 - CodeForces 828E DNA Evolution(树状数组)题解
			
题意:给你一个串k,进行两个操作: “1 a b”:把a位置的字母换成b “2 l r s”:求l到r有多少个字母和s匹配,匹配的条件是这样:从l开始无限循环s形成一个串ss,然后匹配ss和指定区间的 ...
 - Owin对Asp.net Web的扩展
			
类库Microsoft.Owin.Host.SystemWeb 扩展HttpContext以及HttpRequest ,新增了方法GetOwinContext // // Summary: // Pr ...
 - jq对象和DOM对象的互换
			
var oJq; //JQ对象 var oDom; //dom对象 oDom = oJq[index]; // JQ对象转化为oDom对象 oJq = $(oDom); //DOM对象 ...
 - 《图解Http》 2-6章: 基础,报文,状态码,首部。
			
HTTP协议和Cookie 是stateless协议,自身不对请求和响应之间的通信状态进行保存.但随着技术发展,为了实现保存状态的功能,引入了Cookie技术. Cookie在请求和响应报文中写入信息 ...
 - Andrew and Taxi CodeForces - 1100E (思维,拓扑)
			
大意: 给定有向图, 每条边有一个权值, 假设你有$x$个控制器, 那么可以将所有权值不超过$x$的边翻转, 求最少的控制器数, 使得翻转后图无环 先二分转为判定问题. 每次check删除能动的边, ...
 - 解决:Android 8.0检测不到当前的activity
			
前两天从Android 7.0升级到Android 8.0,今天在用 adb shell dumpsys activity | findstr "mFocusedActivity" ...
 - vue 父组件传递数据给子组件
			
父组件 <body> <div id="app"> <child v-bind:data = "test"></chi ...
 - asp.net中的时间日期选择控件
			
asp.net中的时间日期选择控件 Posted on 2008-07-17 17:37 飛雪飄寒 阅读(22922) 评论(6) 编辑 收藏 在系统中经常需要进行时间日期选择(比如查询时间范 ...
 - 『转』Emsisoft Anti-Malware 8刷Key教程 - 文字版
			
先分主机和客机,下载好 EAM8安装包 和 30天重置工具EAM Trial Reset 1.1.exe 1. 主机安装 Emsisoft Anti-Malware 8 并激活30天试用版 如果已 ...