AngularJS简介
AngularJS 诞生于2009年,由Misko Hevery 等人创建,后为Google所收购。是一款优秀的前端JS框架,已经被用于Google的多款产品当中。AngularJS有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、依赖注入等等。
AngularJS四大特征
MVC模式
Angular遵循软件工程的MVC模式,并鼓励展现,数据,和逻辑组件之间的松耦合,通过依赖注入(dependency injection),Angular为客户端的Web应用带来了传统服务端的服务,例如独立于视图的控制。 因此,后端减少了许多负担,产生了更轻的Web应用。

Model:数据,其实就是angular变量($scope.XX);
View: 数据的呈现,Html+Directive(指令);
Controller:操作数据,就是function,数据的增删改查;
双向绑定
AngularJS是建立在这样的信念上的:即声明式编程应该用于构建用户界面以及编写软件构建,而指令式编程非常适合来表示业务逻辑。框架采用并扩展了传统HTML,通过双向的数据绑定来适应动态内容,双向的数据绑定允许模型和视图之间的自动同步。因此,AngularJS使得对DOM的操作不再重要并提升了可测试性。

依赖注入
依赖注入(Dependency Injection,简称DI)是一种设计模式, 指某个对象依赖的其他对象无需手工创建,只需要“吼一嗓子”,则此对象在创建时,其依赖的对象由框架来自动创建并注入进来,其实就是最少知识法则;模块中所有的service和provider两类对象,都可以根据形参名称实现DI.
模块化设计
高内聚低耦合法则
1)官方提供的模块 ng、ngRoute、ngAnimate
2)用户自定义的模块 angular.module(‘模块名’,[ ])
语法
表达式
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-1 表达式</title>
<!-- 引入angularJS -->
<script src="./angular.min.js"></script>
</head>
<!--
ng-app 指令用于告诉 AngularJS 应用当前这个元素是根元素。
所有 AngularJS 应用都必须要要一个根元素。
HTML 文档中只允许有一个 ng-app 指令,如果有多个 ng-app 指令,则只有第一个会被使用
-->
<body ng-app>
{{100+100}}
</body>
</html>
双向绑定
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-2 双向绑定</title>
<!-- 引入angularJS -->
<script src="./angular.min.js"></script>
</head>
<body ng-app>
<!-- ng-model 通过文本框绑定变量 -->
请输入姓名:<input ng-model="name"/></br>
<!-- 使用差值表达式输出变量 -->
{{name}}</br>
<!-- 其他表单使用已绑定的变量 -->
<input ng-model="name"/>
</body>
</html>
初始化指令
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-3 初始化指令</title>
<!-- 引入angularJS -->
<script src="./angular.min.js"></script>
</head>
<!-- ng-init 可以变变量进行初始化 -->
<body ng-app ng-init="name='小金爱编程'">
请输入姓名:
<!-- 使用差值表达式输出变量 -->
{{name}}</br>
<!-- 其他表单使用已绑定的变量 -->
<input ng-model="name"/>
</body>
</html>
控制器
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-4 控制器</title>
<script src="./angular.min.js"></script>
<script>
//建立模块 第一个参数模块名 第二个模块放数组,可以放入其他模块
var app = angular.module("myapp",[]);
//创建控制器 第一个参数为控制器名称 第二个参数为方法
//$scope 就是控制层与视图层之间交换数据的桥梁
app.controller("myController",function($scope){
//函数类型的变量
$scope.add=function(){
/* $scope.x获取对象 */
return parseInt($scope.x)+parseInt($scope.y);
}
});
</script>
</head>
<!-- 指定模块名与script定义的模块名相同 -->
<!-- ng-controller 指定控制器的名称 -->
<body ng-app="myapp" ng-controller="myController">
第一个数:<input ng-model="x"/></br>
第二个数:<input ng-model="y"/></br>
<!-- {{x+y}} -->
<!-- 调用add方法 -->
{{add()}}
</body>
</html>
事件指令
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-5 事件指令</title>
<script src="./angular.min.js"></script>
<script>
var app = angular.module("myapp",[]);
//创建控制器 第一个参数为控制器名称 第二个参数为方法
//$scope 就是控制层与视图层之间交换数据的桥梁
app.controller("myController",function($scope){
//函数类型的变量
$scope.add=function(){
/* $scope.x获取对象 */
$scope.z = parseInt($scope.x)+parseInt($scope.y);
}
});
</script>
</head>
<!-- 指定模块名与script定义的模块名相同 -->
<!-- ng-controller 指定控制器的名称 -->
<body ng-app="myapp" ng-controller="myController">
第一个数:<input ng-model="x"/></br>
第二个数:<input ng-model="y"/></br>
<button ng-click="add()">运算</button></br>
运算结果:{{z}}
</body>
</html>
循环数组
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-6 循环数组</title>
<script src="./angular.min.js"></script>
<script>
var app = angular.module("myapp",[]);
app.controller("myController",function($scope){
$scope.list=[102,203,394,555];
});
</script>
</head>
<body ng-app="myapp" ng-controller="myController">
<table>
<!-- 循环,你想循环什么就在哪里加repeat -->
<tr ng-repeat="x in list">
<td>
{{x}}
</td>
</tr>
</table>
</body>
</html>
循环对象数组
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>angularJS入门小demo-7 循环数组</title>
<script src="./angular.min.js"></script>
<script>
var app = angular.module("myapp",[]);
app.controller("myController",function($scope){
$scope.list=[
{
name:'小金',
mathScore:100,
historyScore:100
},
{
name:'小赵',
mathScore:99,
historyScore:95
},
{
name:'小张',
mathScore:88,
historyScore:98
},
];
});
</script>
</head>
<body ng-app="myapp" ng-controller="myController">
<table style="text-align: center;">
<tr>
<td>姓名</td>
<td>数学成绩</td>
<td>历史成绩</td>
</tr>
<tr ng-repeat="student in list">
<td>{{student.name}}</td>
<td>{{student.mathScore}}</td>
<td>{{student.historyScore}}</td>
</tr>
</table>
</body>
</html>
内置服务
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>angularJS入门小demo-8 内置服务</title>
<script src="angular.min.js"></script>
<script>
var app = angular.module("myapp",[]);
app.controller("myController",function($scope,$http){
//在方法中获取json对象
$scope.findList=function(){
//成功后返回response结果
$http.get("data.json").success(
function(response){
$scope.list=response;
}
);
}
});
</script>
</head>
<body ng-app="myapp" ng-controller="myController" ng-init="findList()">
<table style="text-align: center;">
<tr>
<td>姓名</td>
<td>数学成绩</td>
<td>历史成绩</td>
</tr>
<tr ng-repeat="student in list">
<td>{{student.name}}</td>
<td>{{student.mathScore}}</td>
<td>{{student.historyScore}}</td>
</tr>
</table>
</body>
</html>
注:我在同级中放了data.json文件










