AngularJS 的常用特性(二)
3、列表、表格以及其他迭代型元素
ng-repeat可能是最有用的 Angular 指令了,它可以根据集合中的项目一次创建一组元素的多份拷贝。
比如一个学生名册系统需要从服务器上获取学生信息,目前先把模型之间定义在 JavaScript 代码里面:
var students = [{name: 'Mary', id: '1'}, {name: 'Jack', id: '2'}, {name: 'Jill', id: '3'}]; function StudentListController($scope) { $scope.students = students; }
为了显示这个学生列表,可以编写如下代码:
<ul ng-controller="StudentListController"> <li ng-repeat="student in students"> <a href="/student/view/{{student.id}}">{{student.name}}</a> </li> </ul>
ng-repeat 将会生成标签内部所有 HTML 元素的一份拷贝,包括放指令的标签,显示结果如下:
根据具体情况分别链接到 /student/view/1、/student/view/2 以及 /student/view/3。
ng-repeat 指令可以通过 $index 返回当前引用的元素序号(类似<s:iterator>标签中的 index),还可以通过 $first、$middle及 $last,ng-repeat 指令返回布尔值。
4、隐藏和显示
对于菜单、上下文敏感的工具以及很多其他情况来说,显示和隐藏元素是一项核心功能。
ng-show 和 ng-hide 指令的功能是等价的,但是运行效果正好相反。
ng-show 在表达式为 true 时将会显示元素,为 false 时将会隐藏元素;而 ng-hide 则恰好相反。
工作原理:根据实际情况把元素的样式设置为 display : block 来显示元素;设置为 display : none 来隐藏元素。
5、CSS 类和样式
目前你已经可以在应用中动态地设置 CSS 类和样式了,只有使用{{ }}插值语法把它们进行数据绑定即可,甚至可以在模板中构造 CSS 类名的部分匹配方式。
.menu-disabled-true { color: gray; }
使用以下模板,可以将功能显示成禁用状态:
<div ng-controller="MenuController"> <ul> <li class="menu-disabled-{{isDisabled}}" ng-click="DisabledIt()">Click</li> ... </ul> </div>
这样通过控制器来设置 isDisabled 属性:
function MenuController($scope) { $scope.isDisabled = false; $scope.disabledIt = function() { $scope.isDisabled = true; } }
这样,只有 isDisabled 为 true 时,拼接出来的才是 menu-disabled-true,CSS 样式才会起作用。
当使用插值的方式绑定内联样式的时候,同样适用,例如 style = "{{some.expression}}"。
但是由于这种方式并不灵活,后期维护困难,所以 Angular 中推荐使用 ng-class 和 ng-style 指令。
这两个指令都可以接受一个表达式,表达式执行的结果可能是如下取值之一:
- 表示 CSS 类名的字符串,以空格分隔
- CSS 类名数组
- CSS 类名到布尔值的映射
我们可以如下实现显示错误和警告信息的功能:
.error { background-color: red; } .warning { background-color: yellow; } <div ng-controller="HeaderController"> ... <div ng-class="{error: isError, warning: isWarning}">{{messageText}}</div> ... <button ng-click="showError()">Simulate Error</button> <button ng-click="showWarning()">Simulate Warning</button> </div> function HeaderController($scope) { $scope.isError = false; $scope.isWarning = false; $scope.showError = function () { $scope.messageText = 'This is an error'; $scope.isError = true; $scope.isWarning = false; }; $scope.showWarning = function () { $scope.messageText = 'Just a warning, Please carry on.'; $scope.isWarning = true; $scope.isError = false; } }
你会发现这样实现的很优雅,而且容易维护,下面还可以做一个更炫的事情,例如,把表格中被选中的行进行高亮显示。
首先,在 CSS 中设置一个样式:
.selected { background-color: lightgreen; }
在模板中,我们把 ng-class 设置为 {selected: $index == selectedRow},当模型属性 selectedRow 的值等于 ng-repeat 中的 $index 时,selected 样式就会设置到对应的那一行。
<table ng-controller="RestaurantTableController"> <tr ng-repeat="restaurant in directory" ng-click="selectRestaurant($index)" ng-class="{selected : $index == selectedRow}"> <td>{{restaurant.name}}</td> <td>{{restaurant.cuisine}}</td> </tr> </table>
创建控制器:
1 var app = angular.module('app', []); 2 3 app.controller('RestaurantTableController', function ($scope) { 4 $scope.directory = [{name: 'The Handsome Heifer', cuisine: 'BBQ'}, 5 {name: 'Green\'s Green Greens', cuisine: 'Salads'}, 6 {name: 'House of Fine Fish', cuisine: 'Seafood'}]; 7 }); 8 9 $scope.selectRestaurant = function (row) { 10 $scope.selectedRow = row; 11 }
显示效果如图:
特别感谢:《用 AngularJS 开发下一代 Web 应用》
AngularJS 的常用特性(二)的更多相关文章
- AngularJS 的常用特性(五)
13.使用路由和 $location 切换视图 对于一些单页面应用来说,有时候需要为用户展示或者隐藏一些子页面视图,可以利用 Angular 的 $route 服务来管理这种场景. 你可以利用路由服务 ...
- AngularJS 的常用特性(一)
前言:AngularJS 是一款来自 Google 的前端 JS 框架,该框架已经被应用到了 Google 的多款产品中,这款框架最核心特性有:MVC.模块化.自动化双向数据绑定.语义化标签.依赖注入 ...
- AngularJS 的常用特性(四)
11.使用 Module(模块) 组织依赖关系 Angular 里面的模板,提供了一种方法,可以用来组织应用中一块功能区域的依赖关系:同时还提供了一种机制,可以自动解析依赖关系(又叫依赖注入),一般来 ...
- AngularJS 的常用特性(三)
6.表达式 在模板中使用表达式是为了以充分的灵活性在模板.业务逻辑和数据之间建立联系,同时又能避免让业务逻辑渗透到模板中. <div ng-controller="SomeContr ...
- C#网络程序设计(1)网络编程常识与C#常用特性
网络程序设计能够帮我们了解联网应用的底层通信原理! (1)网络编程常识: 1)什么是网络编程 只有主要实现进程(线程)相互通信和基本的网络应用原理性(协议)功能的程序,才能算是真正的网 ...
- Unity3D编辑器扩展(五)——常用特性(Attribute)以及Selection类
前面写了四篇关于编辑器的: Unity3D编辑器扩展(一)——定义自己的菜单按钮 Unity3D编辑器扩展(二)——定义自己的窗口 Unity3D编辑器扩展(三)——使用GUI绘制窗口 Unity3D ...
- 常用模块二(hashlib、configparser、logging)
阅读目录 常用模块二 hashlib模块 configparse模块 logging模块 常用模块二 返回顶部 hashlib模块 Python的hashlib提供了常见的摘要算法,如MD5,SH ...
- 第三节:Vuejs常用特性2和图书案例
一. 常用特性2 1. 监听器 用watch来响应数据的变化, 一般用于异步或者开销较大的操作, watch 中的属性 一定是data 中 已经存在的数据!!! 当需要监听一个对象的改变时,普通的wa ...
- C++11常用特性介绍——auto类型修饰符
1.C++11常用特性介绍 从本篇开始介绍C++11常用特性,大致分:关键字及新语法.STL容器.多线程.智能指针内存管理,最后讲一下std::bind和std::function 二.关键字和新语法 ...
随机推荐
- java 传参数时 类型后跟 3个点 "..." 的意义
对照代码和运行结果便知"..." 的意义 import java.util.ArrayList; public class StringDemo { public static v ...
- NTLM认证协议及SSPI的NTLM实现
没错,NTLM就是你听说过的那个NTLM.是微软应用最广泛的认证协议之一. NTLM是NT LAN Manager的缩写,这也说明了协议的来源.NTLM 是 Windows NT 早期版本的标准安全协 ...
- [转载]灵动思绪EF(Entity FrameWork)
很久之前就想写这篇文章了,但是由于种种原因,没有将自己学习的EF知识整理成一片文章.今天我就用CodeFirst和ModelFirst两种方式的简单案例将自己学习的EF知识做个总结. 在讲解EF之前, ...
- 遍历datatable的几种方法(C# )
转载 遍历datatable的方法2009-09-08 10:02方法一: DataTable dt = dataSet.Tables[0]; for(int i = 0 ; i ...
- WPF自定义ComboBox
<ControlTemplate x:Key="ComboBoxTextBox" TargetType="{x:Type TextBox}"> &l ...
- iOS Apple Watch 开发
1. Watch OS 1 与 Watch OS 2 的区别 : OS 1 中界面运行在手表上,而代码(Extension)运行在手机端:OS 2 是纯正的手表原生(Native)应用 由于架构的改变 ...
- 【性能分析】使用Intel VTune Amplifier
本文转自 https://software.intel.com/zh-cn/blogs/2010/11/10/amplxe-cl/版权归原作者所有,如原作者有任何不允许转载之理由,本文将自行删除. I ...
- 敏感词过滤的算法原理之DFA算法
参考文档 http://blog.csdn.net/chenssy/article/details/26961957 敏感词.文字过滤是一个网站必不可少的功能,如何设计一个好的.高效的过滤算法是非常有 ...
- java后台简单从腾讯云下载文件通知前端以附件的形式保存
腾讯云对象存储和阿里云差不多 这是我的配置 /** * 腾讯云client * @return COSClient */ public static COSClient getCOSClient() ...
- pickle 模块学习 常用方法
内容提要: 1: pickle的主要作用 pickle主要用于python 于python 之间进行文件传出,网络传输 他同json 一样也是有4个函数 pickle.dumps(iterable) ...