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 ...
随机推荐
- Dockerfile详解
Dockerfile详解 利用Dockerfile文件,可以构建docker的image镜像 命令使用 通过-f参数指定Dockerfile路径,进行构建image docker build -f / ...
- oracle系列笔记(1)---查询数据
查询数据 1. 查询(select .. form ..) (1)普通查询 select * from employees --代表查询employees表中所有数据 select last_n ...
- fetch使用的常见问题及解决办法
首先声明一下,本文不是要讲解fetch的具体用法,不清楚的可以参考MDN fetch教程. 引言 说道fetch就不得不提XMLHttpRequest了,XHR在发送web请求时需要开发者配置相关请求 ...
- Python求解数组重新组合求最小值(优酷)
题目描述:题目:含有n个元素的整型数组,将这个n个元素重新组合,求出最小的数,如(321,3,32,) 最小数为321323 题目分析: 将数组中所有元素填充到个数相等,填充的数字为最后一位的数字,如 ...
- smarty模板基础1
smarty模板的作用可以让前端和后端分离(也就是前端的显示页面和后端的php代码). smarty模板的核心是一个类,下载好的模板中有这么几个重要的文件夹 (1)libs核心文件夹(2)int.in ...
- MAC本如何优雅的创建定时任务
在MACOS上设置定时任务大体有两种方案.一种是使用crontab,一种是使用Schedule,今天结合我的使用简单介绍一下. 先说一下背景,为什么MAC可以用crontab.如果使用过Linux的同 ...
- 2017-3-2 C# WindowsForm 中label标签居中显示
有时候label标签要输出 label.text=""; 的语句,那么要把这个语句居中显示 1.要取消他的Autosize的值 2.拉大这个框,设置里面的文本的TextAlign ...
- Java面试系列
如果你的面试简历是如下这样写的,请务必准备回答下面的所有问题. 面试职位:Java高级工程师 专业技能: (1)牢固掌握Java基础知识,如集合.并发.I/O等,并对Java源码有一定的研究. (2) ...
- Struts2自定义拦截器Interceptor以及拦截器登录实例
1.在Struts2自定义拦截器有三种方式: -->实现Interceptor接口 public class QLInterceptorAction implements Interceptor ...
- 使用Git将本地仓库与GitHub远程仓库相关联
这篇文章详细讲解了如何生成SSH,并链接到GitHub,123..... 1.如果你的GitHub里面没有仓库,就自己生成一个,如图所示 2.如果你有自己仓库,想在电脑本地新建一个,你需要将GitHu ...