学了前面这么多关于指令的知识,现在就用指令来写一个小组件: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

最新文章

  1. 扩展jQuery easyui datagrid增加动态改变列编辑的类型
  2. Android工程目录及其作用简介
  3. 解决mysql 1040错误Too many connections的方法
  4. Input File 表单上传按钮美化
  5. STL中erase的小心使用
  6. php socket 超时设置
  7. ARM过程调用标准---APCS简单介绍
  8. js获取编辑框游标的位置
  9. PHP算法学习(2) 轮训加权算法
  10. Android Studio 之 项目瘦身、代码检查
  11. git关联了无用的,取消关联,并重置gitignore
  12. Spring boot Mybatis 整合(完整版)
  13. Bootstrap 辅助类
  14. 最优化方法:共轭梯度法(Conjugate Gradient)
  15. 红楼梦人物关系图,一代大师成绝响,下回分解待何人,kindle读书摘要
  16. 如何让VS2012编写的程序在XP下运行
  17. Zabbix自动发现之fping
  18. URAL 1997 Those are not the droids you&#39;re looking for 二分图最大匹配
  19. Python2中编码错误---&#233;‡&#231;&#187;„&#228;&#186;&#186;&#232;&#161;&#168;&#231;š&#174;&#231;”Ÿ&#233;•&#191;&#229;›&#160;&#229;&#173;&#229;‡&#232;ƒ&#182;(&#230;˜“&#229;&#173;š格式转化为UTF-8
  20. UVA 11995 STL 使用

热门文章

  1. LR函数基础(一)(二)
  2. uml中活动图与流程图的区别
  3. Ubuntu 1604配置安装mysql8.0
  4. 转:CMake 使用方法
  5. [转载]Linux下终端字体颜色设置方法
  6. url 中非法字符替换,java 正则替换
  7. 通用MYSQL5.5和5.6源码包安装
  8. “医疗信息化行业之中的联发科”- 我们在医疗行业中的定位及目标 想做一个面对中小企业的专业上游软件供应商 台湾联发科技颠覆掉的是一个封闭的手机产业系统 解决方案,即AgileHIS.NET数字化医院基础方案
  9. 保证java的jar包在后台运行
  10. 【Oracle】详解ORACLE中的trigger(触发器)