详解JavaScript的AngularJS框架中的表达式与指令


Posted in Javascript onMarch 05, 2016

“指令属性”就是绑定在DOM元素上的函数,它可以调用方法、定义行为、绑定controller及$scope对象、操作DOM,等等等等。

当浏览器启动、开始解析HTML(像平时一样)时,DOM元素上的指令属性就会跟其他属性一样被解析。

当一个Angular.js应用启动,Angular编译器就会遍历DOM树(从有ng-app指令属性的那个DOM元素开始,如我们在本系列第一篇里所提过的),解析HTML,寻找这些指令属性函数。

当在一个DOM元素上找到一个或多个这样的指令属性函数,它们就会被收集起来、排序,然后按照优先级顺序被执行。

每个指令属性都有自己的优先级,在我们关于指令属性的专题文章里(http://www.ng-newsletter.com/posts/directives.html),你可以找到更深入的信息。

Angular.js应用的动态性和响应能力,都要归功于指令属性。之前我们已经看过一些指令属性的用例:

ng-model

<input ng-model="name" name="Name" placeholder="Enter your name"/>
<h4>Your name: {{ name }}</h4>

试试看

详解JavaScript的AngularJS框架中的表达式与指令

ng-model指令属性(我们在之前的章节使用过它),被用来将DOM文本输入框的值,跟controller里的$scope model绑定起来。具体的实现过程,是在这个值上绑定了一个$watch函数(类似JavaScript里的事件监听函数)。

$watch函数(在使用时)运行在Angular.js的事件循环(即$digest循环)里,让Angular.js能够对DOM进行相应的更新。请关注我们关于$digest循环的高级文章!

在Angular.js应用的开发中,我们用指令属性来将行为绑定到DOM上。指令属性的使用,是一个 应用能否拥有动态性、响应能力的关键。Angular.js提供了很多缺省的指令属性,现在让我们来看看其中几个,以及如何使用它们。

几个常见的指令属性:

{{ 表达式 }}

这个双大括号指令属性,使用$watch()函数,给括号内的表达式注册了一个监听器。正是这个$watch函数,让Angular.js能够实时自动更新view。

那么,到底什么算是个表达式?
要想理解指令属性的运作,我们必须先理解表达式,所以这里我们就绕个路,看看本系列的第五部分——表达式。在之前的例子里我们已经见过表达式,例如 {{ person.name }} 和 {{ clock }}。

{{ 8 + 1 }}9
{{ person }}{"name":"Ari Lerner"}
{{ 10 * 3.3 | currency }}$33.00

最后的例子里 (10 * 3.3 | currency) 用了一个过滤器。本系列之后的部分,会深入介绍过滤器。

表达式粗略来看有点像 eval(javascript) 的结果。它们会经过Angular.js的处理,从而拥有以下重要而独特的性质:

所有表达式都在scope这个context里被执行,因此可以使用所有本地 $scope 中的变量。
如果一个表达式的执行导致类型错误或引用错误,这些错误将不会被抛出。
表达式里不允许任何控制函数流程的功能(如if/else等条件语句)
表达式可接受一个或多个串联起来的过滤器。
试试看

详解JavaScript的AngularJS框架中的表达式与指令

试试输入“person“,“clock“或其他数学算式如2+4。你甚至可以操作scope,例如,试试输入person.name = ”Ari”; person.age = 28; person 或 clock

表达式都运行在调用它们的scope里,所以一个表达式可访问并操作其scope上的一切。由此,你可以使用表达式遍历其scope的属性(我们在ng-repeat中会看到这一应用)、调用scope里的函数,或者对scope中的变量进行数学运算。

现在,让我们回到指令属性…

ng-init

ng-init指令属性是一个在启动时运行的函数(在程序进入运行阶段之前)。它让我们能够在程序运行前设定初始变量的值:

<b ng-init='name = "Ari Lerner"'>Hello, {{ name }}</b>

试试看

Hello, Ari Lerner

ng-click

ng-click指令属性给DOM元素注册了一个点击事件的监听器。当此DOM元素上有点击事件发生(即当此button或link被点击时),Angular.js就会执行表达式的内容,并相应地更新view。

<button ng-click="counter = counter + 1">Add one</button>
Current counter: {{ counter }}

试试看

详解JavaScript的AngularJS框架中的表达式与指令

我们也可以用ng-click 来调用在controller里写好并绑定在$scope上的函数,例如:

<button ng-click="sayHello()">Say hello</button>

controller 里的函数:

app.controller('MyController', function($scope) {
  $scope.sayHello = function() {
   alert("hello!");
  }
 });

试试看

详解JavaScript的AngularJS框架中的表达式与指令

ng-show / ng-hide

ng-show和ng-hide指令,根据赋予它们的表达式的值的真假性(truthy),来显示和隐藏它们所属的那一部分DOM。

我们在这里不会深入,但你应该熟悉JavaScript中变量值的“truthy”和“falsy”概念。

<button ng-init="shouldShow = true" ng-click="shouldShow = !shouldShow">Flip the shouldShow variable</button>
 <div ng-show="shouldShow">
  <h3>Showing {{ shouldShow }}</h3>
 </div> <div ng-hide="shouldShow">
  <h3>Hiding {{ shouldShow }}</h3>
 </div>

ng-repeat

ng-repeat指令遍历一个数据集合中的每个数据元素,加载HTML模版把数据渲染出来。被重复使用的模版元素,就是我们绑定了这个指令属性的DOM元素。每一个使用模版渲染的DOM元素都有自己的scope。

在更多的解释之前,我们先看一个例子。假设我们的controller里有这样一个数据元素的数组:

$scope.roommates = [
  { name: 'Ari'},
  { name: 'Q'},
  { name: 'Sean'},
  { name: 'Anand'}
 ];

在view里我们可以用ng-repeat来遍历这个集合里的数据:

<ul>
  <li ng-repeat="person in roommates">{{ person.name }}</li> </ul>

对赋予ng-repeat的表达式稍作改动,我们还可以用它遍历一个由成对的key-value数据组成的集合。例如,假设我们有一个人名和他们最喜欢的颜色的数据集合:

$scope.people = {
  'Ari': 'orange',
  'Q': 'purple',
  'Sean': 'green'
 }

要遍历它,我们可以给ng-repeat指令属性赋予这个表达式: (key, value) in object:

<ul>
  <li ng-repeat="(name, color) in people">{{ name }}'s favorite color is {{ color }}
  </li>
 </ul>

 

Javascript 相关文章推荐
javascript编程起步(第一课)
Jan 10 Javascript
一个用js实现控制台控件的代码
Sep 04 Javascript
初学JavaScript_03(ExtJs Grid的简单使用)
Oct 02 Javascript
精选的10款用于构建良好易用性网站的jQuery插件
Jan 23 Javascript
javascript学习笔记(二十) 获得和设置元素的特性(属性)
Jun 20 Javascript
js中Image对象以及对其预加载处理示例
Nov 20 Javascript
js实现遮罩层划出效果是生成div而不是显示
Jul 29 Javascript
Bootstrap编写一个兼容主流浏览器的受众巨幕式风格页面
Jul 01 Javascript
深入理解vue-router之keep-alive
Aug 31 Javascript
webpack4的迁移的使用方法
May 25 Javascript
JavaScript如何获取一个元素的样式信息
Jul 29 Javascript
Vue 一键清空表单的实现方法
Feb 07 Javascript
深入解析AngularJS框架中$scope的作用与生命周期
Mar 05 #Javascript
JS判断字符串字节数并截取长度的方法
Mar 05 #Javascript
jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
Mar 05 #Javascript
js控制TR的显示隐藏
Mar 04 #Javascript
Node.js操作Firebird数据库教程
Mar 04 #Javascript
实例剖析AngularJS框架中数据的双向绑定运用
Mar 04 #Javascript
node.js微信公众平台开发教程
Mar 04 #Javascript
You might like
Apache, PHP在Windows 9x/NT下的安装与配置 (一)
2006/10/09 PHP
如何使用PHP中的字符串函数
2006/11/24 PHP
用php获取远程图片并把它保存到本地的代码
2008/04/07 PHP
php同时使用session和cookie来保存用户登录信息的实现代码
2016/05/13 PHP
innerhtml用法 innertext用法 以及innerHTML与innertext的区别
2009/10/26 Javascript
javascript学习笔记(二) js一些基本概念
2012/06/18 Javascript
javascript实现json页面分页实例代码
2014/02/20 Javascript
实例讲解避免javascript冲突的方法
2016/01/03 Javascript
深入理解js数组的sort排序
2016/05/28 Javascript
JS 实现计算器详解及实例代码(一)
2017/01/08 Javascript
jQuery实现 上升、下降、删除、添加一行代码
2017/03/06 Javascript
EasyUI创建人员树的实例代码
2017/09/15 Javascript
vue 子组件向父组件传值方法
2018/02/26 Javascript
基于js中的存储键值对以及注意事项介绍
2018/03/30 Javascript
Vue2.0学习系列之项目上线的方法步骤(图文)
2018/09/25 Javascript
详解VUE里子组件如何获取父组件动态变化的值
2018/12/26 Javascript
vue-cli或vue项目利用HBuilder打包成移动端app操作
2020/07/29 Javascript
vue如何使用外部特殊字体的操作
2020/07/30 Javascript
[05:49]2014DOTA2TI4正赛第二日综述 昔日冠军纷纷落马 VG LGD占尽先机
2014/07/20 DOTA
Python深入学习之上下文管理器
2014/08/31 Python
python实现发送和获取手机短信验证码
2016/01/15 Python
使用python装饰器计算函数运行时间的实例
2018/04/21 Python
python看某个模块的版本方法
2018/10/16 Python
python计算阶乘和的方法(1!+2!+3!+...+n!)
2019/02/01 Python
美国LOGO设计公司:The Logo Company
2018/07/16 全球购物
怎么可以提高数据库查询数据的速度
2014/06/28 面试题
大学生个人先进事迹材料范文
2014/05/03 职场文书
体育教师求职信
2014/05/24 职场文书
财政局党的群众路线教育实践活动整改方案
2014/09/21 职场文书
2014年领导班子工作总结
2014/12/11 职场文书
骨干教师个人总结
2015/02/11 职场文书
大学生学生会工作总结2015
2015/05/26 职场文书
村官2015年度工作总结
2015/10/14 职场文书
严以用权专题学习研讨会发言材料
2015/11/09 职场文书
2016年中秋祝酒词
2015/11/26 职场文书
Java中常用解析工具jackson及fastjson的使用
2021/06/28 Java/Android