angular学习笔记(三十)-指令(9)-一个简单的指令示例
学了前面这么多关于指令的知识,现在就用指令来写一个小组件:expander
这个组件的功能就是点击开展菜单,再点击收起菜单:
↑↓点击展开收起
下面来看它的代码:
html:
<!DOCTYPE html>
<html ng-app="expanderModule">
<head>
<title>20.9 指令-expander</title>
<meta charset="utf-8">
<link href="../bootstrap.css" rel="stylesheet">
<script src="../angular.min.js"></script>
<script type="text/ng-template" id="text.html">
<div class="btn-group">
<button class="btn btn-primary btn-sm dropdown-toggle" type="button" data-toggle="dropdown" ng-click="toggle()">
{{title}}<span class="caret"></span>
</button>
<ul class="dropdown-menu" ng-show="ifShow" ng-transclude>
</ul>
</div>
</script>
<script src="script.js"></script>
<style type="text/css">
body{
padding:40px
}
</style>
</head>
<body>
<div ng-controller="expanderCtrl">
<expander my-title="{{title}}">
<li ng-repeat="content in contents">
<a href="">{{content}}</a>
</li>
</expander>
</div>
</body>
</html>
js:
/*20.9 指令*/
var expanderModule = angular.module('expanderModule',[]);
expanderModule.controller('expanderCtrl',function($scope){
$scope.title = "标题";
$scope.contents = ['bunny','cat','dog'];
});
expanderModule.directive('expander',function(){
return {
restrict:'EA',
replace:true,
templateUrl:'text.html',
transclude:true,
scope:{title:'@myTitle'},
link:function(scope,ele,attrs){
scope.ifShow = false;
scope.toggle = function(){
scope.ifShow = !scope.ifShow;
}
}
}
});
//指令元素里原本就包含的内容,他的作用域使用元素所在的作用域的父作用域,而不是指令的独立scope,所以contents值可以访问到控制器的contents,但是template里面的值却是访问指令独立作用域的.
//这里的myTitle不会被修改,所以采用@和=绑定都可以
下面来分析一下这个指令:
1.创建一个名叫expander的指令,它的类型是元素
2.指令元素里面放置的是子菜单的内容,注意是内容,不是整个ul.因为它要作为一坨插入到ng-transclude元素中,所以,ul必须充当ng-transclude这个元素的角色,然后设置transclue:true.
3.指令的my-title属性用于绑定父作用域的title属性.在这个案例中,使用@绑定和使用=绑定都是可以的.
4.在link函数里给指令独立scope添加ifShow属性.然后在ul子菜单里通过ng-show="ifShow"来绑定它的显示与隐藏
5.在link函数里给指令独立scope添加toggle()方法,切换ifShow.然后给按钮绑定ng-click="toggle()",来改变ifShow的值.
6.在控制器里添加相关的数据模型:title和contents
*7.这一点很重要:
我在expander指令元素里面写了:ng-repeat="content in contents".
然后在text.html模板里写了:ng-click="toggle()" , {{title}} , ng-show="ifShow".
对于expander指令元素来说,写在它里面的内容,它的作用域就是指令所在的元素的作用域,也就是父作用域,所以它可以访问到控制器里的contents模型.
但是text.html,作为指令的模板,被替换到指令,写在模板里面的内容,它的作用域就是指令的独立作用域.也就是指令里定义的scope,所以它是不能访问到contents的,而toggle方法,ifShow属性,都已经在写link函数时,通过scope参数给指令独立作用域绑定了这两个属性和方法.title属性也通过@策略绑定父作用域的title属性.
总结来说就是:原来就写在指令里面的内容,它的作用域还是父作用域,和指令的scope无关.
指令的template里面的内容,它的作用域是指令的作用域,就是定义指令时候写的scope属性
完整代码:https://github.com/OOP-Code-Bunny/angular/blob/master/OREILLY/20.9%20%E6%8C%87%E4%BB%A4.html
https://github.com/OOP-Code-Bunny/angular/blob/master/OREILLY/script.js
angular学习笔记(三十)-指令(9)-一个简单的指令示例的更多相关文章
- angular学习笔记(三十)-指令(10)-require和controller
本篇介绍指令的最后两个属性,require和controller 当一个指令需要和父元素指令进行通信的时候,它们就会用到这两个属性,什么意思还是要看栗子: html: <outer‐direct ...
- angular学习笔记(三十)-指令(7)-compile和link(1)
这篇主要讲解指令中的compile,以及它和link的微妙的关系. link函数在之前已经讲过了,而compile函数,它和link函数是不能共存的,如果定义了compile属性又定义link属性,那 ...
- angular学习笔记(三十)-指令(6)-transclude()方法(又称linker()方法)-模拟ng-repeat指令
在angular学习笔记(三十)-指令(4)-transclude文章的末尾提到了,如果在指令中需要反复使用被嵌套的那一坨,需要使用transclude()方法. 在angular学习笔记(三十)-指 ...
- angular学习笔记(三十)-指令(5)-link
这篇主要介绍angular指令中的link属性: link:function(scope,iEle,iAttrs,ctrl,linker){ .... } link属性值为一个函数,这个函数有五个参数 ...
- angular学习笔记(三十)-指令(2)-restrice,replace,template
本篇主要讲解指令中的 restrict属性, replace属性, template属性 这三个属性 一. restrict: 字符串.定义指令在视图中的使用方式,一共有四种使用方式: 1. 元素: ...
- angular学习笔记(三十)-指令(7)-compile和link(2)
继续上一篇:angular学习笔记(三十)-指令(7)-compile和link(1) 上一篇讲了compile函数的基本概念,接下来详细讲解compile和link的执行顺序. 看一段三个指令嵌套的 ...
- angular学习笔记(三十)-指令(1)-概述
之前在 angular学习笔记(十九)-指令修改dom 里面已经简单的提到了angular中的指令,现在来详细的介绍 '指令' 一.指令的创建: dirAppModule.directive('dir ...
- angular学习笔记(三十)-指令(8)-scope
本篇讲解指令的scope属性: scope属性值可以有三种: 一.scope:false 默认值,这种情况下,指令的作用域就是指令元素当前所在的作用域. 二.scope:true 创建一个继承了父作用 ...
- angular学习笔记(三十)-指令(7)-compile和link(3)
本篇接着上一篇来讲解当指令中带有template(templateUrl)时,compile和link的执行顺序: 把上一个例子的代码再进行一些修改: 1.将level-two指令改成具有templa ...
随机推荐
- 播布客视频PIT专用播放器MBOO2015
播布客视频,还是挺不错... 很多视频都是pit后缀的,需要用MBOO2015才可以打开... 00.MB2015软件 01.视频样例 02.download 链接: https://pan.baid ...
- Win7 64bit下值得推荐的免费看图软件
自从更换到Win7 64bit后, 用了十多年的AcdSee3.x不能再正常工作了. 找到了两个替代品: Faststone Image Viewer 和 XnView Faststone Image ...
- OpenWRT/LEDE长期运行记录截图
哈哈, 发图留念. 待会儿要把它换到别处去了. 在Newifi Y1上稳定运行了95天的自编译OpenWrt, Y1这个型号的特点是5G信号强度比2.4G的强 Update 2017-11-27 在W ...
- 使用Adobe Audition 处理声音步骤
软件: Adobe Audition 3.0 处理声音 插件:单独安装各种DirectX音效处理插件 一.录音 * 录音笔.手机 * Adobe Audition专业的录音软件 二..润 ...
- zabbix v3.0安装部署
这篇文章没有写明init的部分要注意 zabbix v3.0安装部署 摘要: 本文的安装过程摘自http://www.ttlsa.com/以及http://b.lifec-inc.com ,和站长凉白 ...
- k8s实战之数据卷(volume)
一.概述 数据卷用于实现容器持久化数据,k8s对于数据卷重新定义,提供了丰富强大的功能:数据卷分为三类: 本地数据卷,网络数据卷和信息数据卷 二.
- dll版本兼容
<runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <depen ...
- 【Visual Studio】Visual C# 中XML注释的使用(含注释在开发时显示换行)
为函数方法注释说明要用到 xml 语句 <summary> 段落说明 </summary> .<para> 新段示例说明 </para>.<par ...
- MySQL复制的管理和维护
1.查看主库 mysql> show master status; mysql> show master status; +------------------+-----------+- ...
- Ios开发中UILocalNotification实现本地通知实现提醒功能
这两天在做一个日程提醒功能,用到了本地通知的功能,记录相关知识如下: 1.本地通知的定义和使用: 本地通知是UILocalNotification的实例,主要有三类属性: scheduled time ...