AngularJS1.X学习笔记3-内置模板指令
前面学习了数据绑定指令,现在开始学习内置模板指令。看起来有点多,目测比较好理解。OK!开始!
一、ng-repeat
1、基本用法
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>databinding1</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<table width="80%">
<tr><td>事项</td><td>完成否</td></tr>
<tr ng-repeat="item in todos"><td>{{item.action}}</td><td>{{item.complete}}</td></tr>
</table>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.todos = [
{action:"学习1",complete:false},
{action:"学习2",complete:true},
{action:"学习3",complete:false},
{action:"学习4",complete:false},
{action:"学习5",complete:false},
{action:"学习6",complete:false},
];
})
</script>
</body>
</html>
2、操作键值
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>ng-repeat2</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<ul>
<li ng-repeat="item in todos">
<p ng-repeat="(key,value) in item">{{key}}={{value}}</p>
</li>
</ul>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.todos = [
{action:"学习1",complete:false},
{action:"学习2",complete:true},
{action:"学习3",complete:false},
{action:"学习4",complete:false},
{action:"学习5",complete:false},
{action:"学习6",complete:false},
];
})
</script>
</body>
</html>

3、内置变量的使用
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>ng-repeat3</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<table width="80%">
<tr>
<td>序号</td>
<td>事项</td>
<td>完成否</td>
</tr>
<tr ng-repeat="item in todos">
<td>{{$index+1}}</td>
<td>{{item.action}}</td>
<td>{{item.complete}}</td>
</tr>
</table>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.todos = [
{action:"学习1",complete:false},
{action:"学习2",complete:true},
{action:"学习3",complete:false},
{action:"学习4",complete:false},
{action:"学习5",complete:false},
{action:"学习6",complete:false},
];
})
</script>
</body>
</html>
ng-repeat 内置变量一览表
| 变量 | 意义 |
| $index | 返回当前属性或对象的位置(0开始) |
| $first | 当前对象为集合的第一个返回true |
| $middle | 当前对象不是第一个也不是最后一个返回true |
| $last | 当前对象为集合的最后一个返回true |
| $even | 偶数编号为true |
| $odd | 奇数编号为true |
4、重复生成多个顶层元素
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>ng-repeat4</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<table width="80%">
<tr>
<td>序号</td>
<td>事项</td>
<td>完成否</td>
</tr>
<tr ng-repeat-start="item in todos">
<td>第{{$index+1}}项</td>
</tr>
<tr>
<td>
事项是:{{item.action}}
</td>
</tr>
<tr ng-repeat-end>
<td>
{{$index+1}} {{item.complete?"已经":"没有"}} 完成
</td>
</tr>
</table>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.todos = [
{action:"学习1",complete:false},
{action:"学习2",complete:true},
{action:"学习3",complete:false},
{action:"学习4",complete:false},
{action:"学习5",complete:false},
{action:"学习6",complete:false},
];
})
</script>
</body>
</html>
一个项要生成几行,这个时候就需要用这种重复生成顶层元素的方法。
二、ng-include
自由男人说ng-include指令是从服务器获取一段html代码,编译并处理其中包含的任何指令,并添加到DOM中去。
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>databinding1</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<ng-include src="'table.html'"></ng-include>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.todos = [
{action:"学习1",complete:false},
{action:"学习2",complete:true},
{action:"学习3",complete:false},
{action:"学习4",complete:false},
{action:"学习5",complete:false},
{action:"学习6",complete:false},
];
})
</script>
</body>
</html>
我将表格单独做了一个叫做table.html的文件,然后用ng-include引进来了。但是第一次没有成功,检查发现比书上少了两个单引号,这是个坑。自由男人又说了,src属性是被当作js表达式计算的,要静态定义一个文件就得用单引号。
这个指令还有两个属性:onload用于指定在内容被加载时计算的表达式;autoscroll指定内容加载是是否应该滚动到这个区域。另外可以将ng-include用作属性。类似这个样子:
<div ng-include="path" onload="xxx"></div>
三、ng-switch
<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>ng-switch</title>
</head>
<body>
<div ng-controller='dataCtrl'>
<input type="text" name="t" ng-model="data">
<div ng-switch on="data">
<div ng-switch-when="1">
我是data为1的视图。
</div>
<div ng-switch-when="2">
我是data为2的视图。
</div>
<div ng-switch-when="3">
我是data为3的视图。
</div>
<div ng-switch-default>
我是data为默认情况下的视图。
</div>
</div>
</div> <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
<script type="text/javascript">
angular.module('myApp',[])
.controller('dataCtrl',function($scope){
$scope.data = "1";
})
</script>
</body>
</html>
ng-switch on="要检测的数据"
ng-switch-when="要检查的条件"
ng-switch-default 没有满足的
四、其他内置模板指令
| 指令 | 怎么用 | 干嘛的 |
| ng-if | A | 从DOm中删除或者添加元素 |
| ng-show | AC | 显示隐藏元素 |
| ng-hide | AC | 显示隐藏元素 |
| ng-style | AC | 设置CSS属性 |
| ng-class | AC | 为元素指定一个类 |
| ng-class-even | AC | 为偶数元素设置类 |
| ng-class-odd | AC | 为奇数元素设置样式 |
这里不做实验了,做个表用的时候方便查。
预告:接下来学习事件指令!好激动,又学完一个点。加油加油!先活动一下!
AngularJS1.X学习笔记3-内置模板指令的更多相关文章
- flask_admin 笔记五 内置模板设置
内建模板 Flask-Admin是使用jinja2模板引擎 1)扩展内建的模板 不要完全覆盖内置的模板,最好是扩展它们. 这将使您更容易升级到新的Flask-Admin版本. 在内部,Flask-Ad ...
- python自动化测试学习笔记-4内置函数,处理json
函数.全局变量 写代码时注意的几点事项: 1.一般写代码的时候尽量少用或不用全局变量,首先全局变量不安全,大家协作的情况下,代码公用容易被篡改,其次全局变量会一直占用系统内容. 2.函数里如果有多个r ...
- 学习笔记——Maven 内置变量
Maven内置变量说明: ${basedir} 项目根目录(即pom.xml文件所在目录) ${project.build.directory} 构建目录,缺省为target目录 ${project. ...
- Python学习笔记-Day3-python内置函数
python内置函数 1.abs 求绝对值 2.all 判断迭代器中的所有数据是否都为true 如果可迭代的数据的所有数据都为true或可迭代的数据为空,返回True.否则返回False 3.a ...
- 【学习】js学习笔记:内置顶层函数eval()的兼容用法
今天学了一个内置顶层函数,eval();其作用是将字符串转换成javascript命令执行,但必须符合语法,否则会报错. 如果写成window.eval(),则其定义的变量会在全局生效. 但是,在IE ...
- java web 学习笔记 jsp内置对象
jsp2 表达式语言的内置对象 使用方式${object.attributename} 或者${object["attributename"]} pageContext pageS ...
- Python学习笔记-常用内置函数
输出:print() 功能:输出打印 语法:print(*objects, sep=' ', end='\n', file=sys.stdout) 参数:objects----复数,表示可以一次输出多 ...
- [Python学习笔记-001] 内置函数getattr()
如果某个实例foo有多个方法, 当对foo的每一个方法我们都需要使用try ... except ...进行包装的时候,内置函数getattr()可以用来精简代码. 1. getattr()的用法 # ...
- python学习笔记011——内置函数pow()
1 语法 pow(x, y[, z]) x -- 数值表达式. y -- 数值表达式. z -- 数值表达式. 函数是计算 x 的 y 次方,如果 z 在存在,则再对结果进行取模,其结果等效于pow( ...
- Python学习笔记011——内置函数exec()
1 描述 把一个字符串当成语句执行 exec() 执行储存在字符串或文件中的 Python 语句,相比于 eval() , exec() 可以执行更复杂的 Python 代码. exec函数和ev ...
随机推荐
- 使用jQuery快速高效制作网页交互特效
第四章:JQuery选择器 1.Jquery选择器简介 (1) Jquery中的选择器完全继承了CSS的风格,利用Jquery选择器,可以非常便捷和快速的找出特定的Dom元素,然后为他们添加相应的行为 ...
- 每天一个Linux命令(01)--ls命令
ls命令是Linux下最常用的命令.ls命令就是list的缩写,缺省下ls用来打印当前目录的清单,如果ls指定其他目录,那么就会显示指定目录里的文件及文件夹清单.通过ls命令不仅可以查看Linux文件 ...
- C# 字符串比较大小 string.Compare()方法
string.Compare方法,用来比较2个字符串值得大小 string.Compare(str1, str2, true); 返回值: 1 : str1大于str2 0 : str1等于str2 ...
- Tinychatserver: 一个简易的命令行群聊程序
这是学习网络编程后写的一个练手的小程序,可以帮助复习socket,I/O复用,非阻塞I/O等知识点. 通过回顾写的过程中遇到的问题的形式记录程序的关键点,最后给出完整程序代码. 0. 功能 编写一个简 ...
- 最简单的 RabbitMQ 监控方法 - 每天5分钟玩转 OpenStack(158)
这是 OpenStack 实施经验分享系列的第 8 篇. 先来看张图:这是 Nova 的架构图,我们可以看到有两个组件处于架构的中心位置:数据库和Queue.数据库保存状态信息,而几乎所有的 nova ...
- Thread类常用方法
Thread类构造方法: 1.Thread(): 2.Thread(String name): 3.Thread(Runable r): 4.Thread(Runable r, String name ...
- 纯CSS3之五子棋(黑白棋)画法
无聊想用JS写个五子棋玩玩,这边先用CSS3画出了五子棋,感觉挺惊艳的.发上来看看 PS:第一次发博文T-T 此为个人原创. 不多说上图: 代码如下: <!DOCTYPE html> & ...
- iOS 注册密码加密 添加了时间戳 遇到的问题...
今天项目 遇到一个事故,我本想用 一个形容这个事故的adj 算了 既然 叫事故 已经能表达我们处于的一种状态, 是这样的: 有小部分用户反应 app无法注册 总提示密码错误的情况 实际 该步骤 已经 ...
- Java基础——变量、数据类型
一 .变量 1.计算机的内存类似于人的大脑,计算机使用内存来记忆大量运算时要使用数据.内存是一个物理设备,如何来存储一个数据呢?很简单,把内存想象成一间旅馆,要存储的数据就好比要住宿的客人. 首先,旅 ...
- 雪花降落CADisplayLink
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px "PingFang SC"; color: #1d9421 } p.p2 ...