AngularJS 是比较新的技术,版本 1.0 是在 2012 年发布的,是由 Google 的员工 Miško Hevery 从 2009 年开始着手开发,AngularJS 通过 指令 扩展了 HTML,且通过 表达式 绑定数据到 HTML。
1. AngularJS 指令
(1)ng-app 指令告诉 AngularJS,<div> 元素是 AngularJS 应用程序 的"所有者"。
(2)ng-model 指令把输入域的值绑定到应用程序变量 name。
(3)ng-bind 指令把应用程序变量 name 绑定到某个段落的 innerHTML。
(4)ng-init 指令初始化 AngularJS 应用程序变量。
注意:HTML5 允许扩展的(自制的)属性,以 data- 开头,AngularJS 属性以 ng- 开头,但是您可以使用 data-ng- 来让网页对 HTML5 有效。
2.AngularJS 表达式
AngularJS 表达式写在双大括号内:{{ expression }}。
AngularJS 表达式把数据绑定到 HTML,这与 ng-bind 指令有异曲同工之妙。
AngularJS 将在表达式书写的位置"输出"数据。
AngularJS 表达式 很像 JavaScript 表达式:它们可以包含文字、运算符和变量。
实例 {{ 5 + 5 }} 或 {{ firstName + " " + lastName }}
<div ng-app="myApp" ng-controller="myCtrl"> 名: <input type="text" ng-model="firstName"><br> 姓: <input type="text" ng-model="lastName"><br> <br> 姓名: {{firstName + " " + lastName}} </div> <script> var app = angular.module('myApp', []); app.controller('myCtrl', function($scope) { $scope.firstName = "John"; $scope.lastName = "Doe"; }); </script>
AngularJS 应用程序由 ng-app 定义。应用程序在 <div> 内运行。
ng-controller="myCtrl" 属性是一个 AngularJS 指令。用于定义一个控制器。
myCtrl 函数是一个 JavaScript 函数。
AngularJS 使用$scope 对象来调用控制器。
在 AngularJS 中, $scope 是一个应用象(属于应用变量和函数)。
控制器的 $scope (相当于作用域、控制范围)用来保存AngularJS Model(模型)的对象。
控制器在作用域中创建了两个属性 (firstName 和 lastName)。
ng-model 指令绑定输入域到控制器的属性(firstName 和 lastName)。