AngularJS 简介

AngularJS 是一个 JavaScript 框架

AngularJS 通过 指令 扩展了 HTML,且通过 表达式 绑定数据到 HTML

AngularJS 是一个 JavaScript 框架

AngularJS 是一个 JavaScript 框架,是一个用 JavaScript 编写的库

AngularJS 是以一个 JavaScript 文件形式发布的,可通过 script 标签添加到网页中

<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>

我们建议把脚本放在 <body> 元素的底部
这会提高网页加载速度,因为 HTML 加载不受制于脚本加载

此外,你还可以点击以下地址下载其它的版本 https://github.com/angular/angular.js/releases

AngularJS 扩展了 HTML

AngularJS 通过 ng-directives 扩展了 HTML

  1. ng-app 指令定义一个 AngularJS 应用程序

  2. ng-model 指令把元素值(比如输入域的值)绑定到应用程序

  3. ng-bind 指令把应用程序数据绑定到 HTML 视图

<!DOCTYPE html>
<meta charset="utf-8">
<link href="/static/next/css/tryit.css?v=2017082407" rel="stylesheet"/>
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>

<div ng-app="">
  <p>名字 : <input type="text" ng-model="name"></p>
  <h1>Hello {{name}}</h1>
</div>
<footer>简单教程,简单编程<br/>Copyright © 简单教程 www.twle.cn</footer>

运行范例 »

上面的 HTML 文件中,当网页加载完毕,AngularJS 自动开启

  1. ng-app 指令告诉 AngularJS,<div> 元素是 AngularJS 应用程序 的"所有者"

  2. ng-model 指令把输入域的值绑定到应用程序变量 name

  3. ng-bind 指令把应用程序变量 name 绑定到某个段落的 innerHTML

如果我们移除了 ng-app 指令,HTML 将直接把表达式显示出来,不会去计算表达式的结果

什么是 AngularJS ?

AngularJS 使得开发现代的单一页面应用程序(SPA:Single Page Application)变得更加容易

  • AngularJS 把应用程序数据绑定到 HTML 元素
  • AngularJS 可以克隆和重复 HTML 元素
  • AngularJS 可以隐藏和显示 HTML 元素
  • AngularJS 可以在 HTML 元素"背后"添加代码
  • AngularJS 支持输入验证

AngularJS 指令

AngularJS 指令是以 ng 作为前缀的 HTML 属性

ng-init 指令初始化 AngularJS 应用程序变量

<!DOCTYPE html>
<meta charset="utf-8">
<link href="/static/next/css/tryit.css?v=2017082407" rel="stylesheet"/>
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script> 

<div ng-app="" ng-init="firstName='John'">

<p>姓名为 <span ng-bind="firstName"></span></p>

</div>
<footer>简单教程,简单编程<br/>Copyright © 简单教程 www.twle.cn</footer>

运行范例 »

HTML5 允许扩展的(自定义的)属性,以 data- 开头

AngularJS 属性以 ng- 开头,但我们可以使用 data-ng- 来让网页对 HTML5 有效

<!DOCTYPE html>
<meta charset="utf-8">
<link href="/static/next/css/tryit.css?v=2017082407" rel="stylesheet"/>
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script> 

<div data-ng-app="" data-ng-init="firstName='John'">

<p>姓名为 <span data-ng-bind="firstName"></span></p>

</div>
<footer>简单教程,简单编程<br/>Copyright © 简单教程 www.twle.cn</footer>

运行范例 »

AngularJS 表达式

AngularJS 表达式写在双大括号内

{{ expression }}

AngularJS 表达式把数据绑定到 HTML,这与 ng-bind 指令有异曲同工之妙

AngularJS 将在表达式书写的位置 "输出" 数据

AngularJS 表达式很像 JavaScript 表达式

它们可以包含文字、运算符和变量

例如

{{ 5 + 5 }}
{{ firstName + " " + lastName }}

范例

<!DOCTYPE html>
<meta charset="utf-8">
<link href="/static/next/css/tryit.css?v=2017082407" rel="stylesheet"/>
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script> 

<div ng-app="">
  <p>我的第一个表达式: {{ 5 + 5 }}</p>
</div>
<footer>简单教程,简单编程<br/>Copyright © 简单教程 www.twle.cn</footer>

运行范例 »

AngularJS 应用

AngularJS 模块(Module) 定义了 AngularJS 应用

AngularJS 控制器(Controller) 用于控制 AngularJS 应用

ng-app 指令定义了应用, ng-controller 定义了控制器

<!DOCTYPE html>
<meta charset="utf-8">
<link href="/static/next/css/tryit.css?v=2017082407" rel="stylesheet"/>
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script> 

<p>尝试修改以下表单。</p>

<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>
<footer>简单教程,简单编程<br/>Copyright © 简单教程 www.twle.cn</footer>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
    $scope.firstName= "John";
    $scope.lastName= "Doe";
});
</script>

运行范例 »

AngularJS 模块定义应用

var app = angular.module('myApp', []);

AngularJS 控制器控制应用

app.controller('myCtrl', function($scope) {
    $scope.firstName= "John";
    $scope.lastName= "Doe";
});

学习 AngularJS

关于   |   FAQ   |   我们的愿景   |   广告投放   |  博客

  简单教程,简单编程 - IT 入门首选站

Copyright © 2013-2022 简单教程 twle.cn All Rights Reserved.