W3School AngularJS教程
来源:
整理:飞龙
日期:2014.10.1
AngularJS 简介
AngularJS 是一个JavaScript 框架。它可通过 <script> 标签添加到 HTML 页面。AngularJS 通过指令扩展了 HTML,且通过表达式绑定数据到 HTML。AngularJS 是一个 JavaScript 框架
AngularJS 是一个 JavaScript 框架。它是一个以 JavaScript 编写的库。
AngularJS 是以一个 JavaScript 文件形式发布的,可通过 script 标签添加到网页中:<script src="///try/angularjs/1.2.5/angular.min.js"></script>我们建议把脚本放在 <body> 元素的底部。
这会提高网页加载速度,因为 HTML 加载不受制于脚本加载。AngularJS 扩展了 HTML
AngularJS 通过ng-directives扩展了 HTML。
ng-app指令定义一个 AngularJS 应用程序。
ng-model指令把元素值(比如输入域的值)绑定到应用程序。
ng-bind指令把应用程序数据绑定到 HTML 视图。
AngularJS 实例
<!DOCTYPE html>
<html>
<body>
<div ng-app="">
<p>在输入框中尝试输入:</p>
<p>姓名:<input type="text" ng-model="name"></p>
<p ng-bind="name"></p>
</div>
<script src="///try/angularjs/1.2.5/angular.min.js"></script>
</body>
</html>
实例讲解:
当网页加载完毕,AngularJS 自动开启。
ng-app指令告诉 AngularJS,<div> 元素是 AngularJS 应用程序的"所有者"。
ng-model指令把输入域的值绑定到应用程序变量name。
ng-bind指令把应用程序变量 name 绑定到某个段落的 innerHTML。
如果您移除了ng-app指令,HTML 将直接把表达式显示出来,不会去计算
表达式的结果。
什么是 AngularJS?
"AngularJS 是专门为应用程序设计的 HTML。"
AngularJS 使得开发现代的单一页面应用程序(SPAs:Single Page Applications)变得更加容易。
AngularJS 把应用程序数据绑定到 HTML 元素。
AngularJS 可以克隆和重复 HTML 元素。
AngularJS 可以隐藏和显示 HTML 元素。
AngularJS 可以在 HTML 元素"背后"添加代码。
AngularJS 支持输入验证。
AngularJS 指令
正如您所看到的,AngularJS 指令是以ng作为前缀的 HTML 属性。
ng-init指令初始化 AngularJS 应用程序变量。
AngularJS 实例
<div ng-app="" ng-init="firstName='John'">
<p>姓名为 <span ng-bind="firstName"></span></p>
</div>
HTML5 允许扩展的(自制的)属性,以data-开头。
AngularJS 属性以ng-开头,但是您可以使用data-ng-来让网页对 HTML5
有效。
带有有效的 HTML5:
AngularJS 实例
<div data-ng-app="" data-ng-init="firstName='John'">
<p>姓名为 <span data-ng-bind="firstName"></span></p>
</div>
AngularJS 表达式
AngularJS 表达式写在双大括号内:{{ expression }}。
AngularJS 表达式把数据绑定到 HTML,这与ng-bind指令有异曲同工之妙。AngularJS 将在表达式书写的位置"输出"数据。
AngularJS 表达式很像JavaScript 表达式:它们可以包含文字、运算符和变量。实例 {{ 5 + 5 }} 或 {{ firstName + " " + lastName }}
AngularJS 实例
<!DOCTYPE html>
<html>
<body>
<div ng-app="">
<p>我的第一个表达式: {{ 5 + 5 }}</p>
</div>
<script src="///try/angularjs/1.2.5/angular.min.js"></script>
</body>
</html>
AngularJS 表达式
AngularJS 使用表达式把数据绑定到 HTML。
AngularJS 表达式
AngularJS 表达式写在双大括号内:{{ expression }}。
AngularJS 表达式把数据绑定到 HTML,这与ng-bind指令有异曲同工之妙。AngularJS 将在表达式书写的位置"输出"数据。
AngularJS 表达式很像JavaScript 表达式:它们可以包含文字、运算符和变量。
实例 {{ 5 + 5 }} 或 {{ firstName + " " + lastName }}
AngularJS 数字
AngularJS 数据就像 JavaScript 数字:
AngularJS 实例
<div ng-app="" ng-init="quantity=1;cost=5">
<p>总价: {{ quantity * cost }}</p>
</div>
使用 ng-bind 的相同实例:
AngularJS 实例
<div ng-app="" ng-init="quantity=1;cost=5">
<p>总价: <span ng-bind="quantity * cost"></span></p>
</div>
使用ng-init不是很常见。您将在控制器一章中学习到一个更好的初始化数
据的方式。
AngularJS 字符串
AngularJS 字符串就像 JavaScript 字符串:
AngularJS 实例
<div ng-app="" ng-init="firstName='John';lastName='Doe'">
<p>姓名: {{ firstName + " " + lastName }}</p>
</div>
使用 ng-bind 的相同实例:
AngularJS 实例
<div ng-app="" ng-init="firstName='John';lastName='Doe'">
<p>姓名: <span ng-bind="firstName + ' ' + lastName"></span></p>
</div>
AngularJS 对象
AngularJS 对象就像 JavaScript 对象:
AngularJS 实例
<div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}"> <p>姓为 {{ person.lastName }}</p>
</div>
使用 ng-bind 的相同实例:
AngularJS 实例
<div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}"> <p>姓为 <span ng-bind="person.lastName"></span></p>
网页设计html代码大全w3cschool</div>
AngularJS 数组
AngularJS 数组就像 JavaScript 数组:
AngularJS 实例
<div ng-app="" ng-init="points=[1,15,19,2,40]">
<p>第三个值为 {{ points[2] }}</p>
</div>
使用 ng-bind 的相同实例:
AngularJS 实例
<div ng-app="" ng-init="points=[1,15,19,2,40]">
<p>第三个值为 <span ng-bind="points[2]"></span></p>
</div>
AngularJS 指令
AngularJS 通过被称为指令的新属性来扩展 HTML。
AngularJS 指令
AngularJS 指令是扩展的 HTML 属性,带有前缀ng-。
ng-app指令初始化一个 AngularJS 应用程序。
ng-init指令初始化应用程序数据。
ng-model指令把应用程序数据绑定到 HTML 元素。
AngularJS 实例
<div ng-app="" ng-init="firstName='John'">
<p>在输入框中尝试输入:</p>
<p>姓名:<input type="text" ng-model="firstName"></p>
<p>你输入的为: {{ firstName }}</p>
</div>
ng-app指令告诉 AngularJS,<div> 元素是 AngularJS 应用程序的"所有者"。
一个网页可以包含多个运行在不同元素中的 AngularJS 应用程序。
数据绑定
上面实例中的{{ firstName }}表达式是一个 AngularJS 数据绑定表达式。
AngularJS 中的数据绑定,同步了 AngularJS 表达式与 AngularJS 数据。
{{ firstName }}是通过ng-model="firstName"进行同步。
在下一个实例中,两个文本域是通过两个 ng-model 指令同步的:
AngularJS 实例
<div ng-app="" ng-init="quantity=1;price=5">
<h2>价格计算器</h2>
数量: <input type="number" ng-model="quantity">
价格: <input type="number" ng-model="price">
<p><b>总价:</b> {{ quantity * price }}</p>

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。