AngularJS学习教程
AngularJS 是Google的一个 JavaScript 框架,旨在简化前端应用程序的开发。
AngularJS 是比较新的技术,版本 1.0 是在 2012 年发布的。是一款优秀的前端JS框架,已经被用于Google的多款产品当中。
AngularJS 是以一个 JavaScript 文件形式发布的,可通过 script 标签添加到网页中
参考教程:
http://www.runoob.com/angularjs/angularjs-intro.html
引入方式:
<script src="http://{cdn.static}/libs/1.5.8/angular.min.js"></script>
Demo运行地址:
http://www.runoob.com/try/try.php?filename=try_ng_intro
游览器兼容性:
AngularJS 1.3以后抛弃了对IE8的支持。
AngularJS 1.2将继续支持IE8
如果出现兼容性问题,请找度娘,G哥解决吧!
特性:
1) 双向的数据绑定
2) HTML模板
3) MVVM(Moodel-View-ViewModel)
4) 依赖注入
5) Directives(指令)
6) 内置测试用例
接下来针对AngularJS 的特性一一做介绍,详细的标签使用大家可以参考教程自己深度挖掘。
数据绑定可能是AngularJS最酷最实用的特性。它能够帮助你避免书写大量的初始代码从而节约开发时间。
你可以声明绑定的模型到 HTML 元素。当模型发生变化时,视图会自动更新,反之亦然。这可以减少大量的传统样板代码,保持模型和视图同步。
Demo1:
Input输入框和<h1>元素的双向绑定:
Input输入框数据的变化会被自动的更新到<h1>元素中,相对于jquery而言,避免联动代码的开发,让页面变的更清洁。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <div ng-app=""> <p>名字 : <input type="text" ng-model="name"></p> <h1>Hello {{name}}</h1> </div> </body> </html>
Demo2:
checkbox和按钮是否可以点击双向绑定:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <div ng-app="" ng-init="mySwitch=true"> <p> <button ng-disabled="mySwitch">点我!</button> </p> <p> <input type="checkbox" ng-model="mySwitch"/>按钮 </p> <p> {{ mySwitch }} </p> </div> </body> </html>
AngularJS 使用 HTML 模板,这使事情变得简单,并允许设计人员和开发人员同时工作。
最大的好处是为设计师和开发者创建了一个紧密的工作流。设计师可以像往常一样开发标签,然后开发者拿过来添加上功能,通过数据绑定将会使得这个过程非常简单。
Demo3:
将标题属性绑定到<h1>标签中:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body ng-app="myApp" ng-controller="myCtrl"> <h1 ng-repeat="x in records">{{x}}</h1> <script> var app = angular.module("myApp", []); app.controller("myCtrl", function($scope) { $scope.records = [ "菜鸟教程1", "菜鸟教程2", "菜鸟教程3", "菜鸟教程4", ] }); </script> </body> </html>
Demo4:
循环图片数组并且加入img模板:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="../angular.min.js"></script> </head> <body> <div ng-app="myApp" ng-controller="myCtrl"> <ul> <li ng-repeat="image in images"> <img ng-src="{{image.thumbnail}}" alt="{{image.description}}"> </li> </ul> </div> <script> var app = angular.module("myApp", []); app.controller("myCtrl", function AlbumCtrl($scope) { $scope.images = [ {"thumbnail":"img/image_01.jpg", "description":"Image 01 description"}, {"thumbnail":"img/image_02.jpg", "description":"Image 02 description"}, {"thumbnail":"img/image_03.jpg", "description":"Image 03 description"}, {"thumbnail":"img/image_04.jpg", "description":"Image 04 description"}, {"thumbnail":"img/image_05.jpg", "description":"Image 05 description"}, ] }); </script> </body> </html>
MVVM模式是Model-View-ViewMode(模型-视图-视图模型)模式的简称,其最早出现在微软的WPF和Silverlight框架中。MVVM模式利用框架内置的双向绑定技术对MVP(Model-View-Presenter)模式的变型,引入了专门的ViewModel(视图模型)来实现View和Model的粘合,让View和Model的进一步分离和解耦。
双向绑定确实非常使用,通过封装双向绑定中间加了一个概念层ViewMode。
个人感觉跟jquery的mvc基本类似,只不过jquery需要额外的大量js开发。
依赖注入(Dependency Injection,即DI)
AngularJS拥有内建的依赖注入子系统,可以帮助开发人员更容易的开发,理解和测试应用。
DI允许你请求你的依赖,而不是自己找寻它们。比如,我们需要一个东西,DI负责找创建并且提供给我们。
得到核心的AngularJS服务,只需要添加一个简单服务作为参数,AngularJS会侦测并且提供给你:
function EditCtrl($scope, $location, $routeParams) { // Something clever here... }
Demo5:
循环图片数组并且加入img模板:
<html> <head> <meta charset="utf-8"> <title>AngularJS 依赖注入</title> </head> <body> <h2>AngularJS 依赖注入</h2> <div ng-app = "mainApp" ng-controller = "CalcController"> <p>输入一个数字: <input type = "number" ng-model = "number" /></p> <button ng-click = "square()">X<sup>2</sup></button> <p>结果: {{result}}</p> </div> <script src="../angular.min.js"></script> <script> <span style="background-color: rgb(255, 255, 0);">// 定义一个模块</span> var mainApp = angular.module("mainApp", []); <span style="background-color: rgb(255, 255, 0);">// 使用 value给defaultInput赋值</span> mainApp.value("defaultInput", 5); <span style="background-color: rgb(255, 255, 0);">// 创建MathService的factory和具体的方法 </span> mainApp.factory('MathService', function() { var factory = {}; factory.multiply = function(a, b) { return a * b; } return factory; }); <span style="background-color: rgb(255, 255, 0);">// 封装一个CalcService暴露调用</span> mainApp.service('CalcService', function(MathService){ this.square = function(a) { return MathService.multiply(a,a); } }); <span style="background-color: rgb(255, 255, 0);">// 将CalcService和参数传递到控制器</span> mainApp.controller('CalcController', function($scope, CalcService, defaultInput) { $scope.number = defaultInput; $scope.result = CalcService.square($scope.number); $scope.square = function() { $scope.result = CalcService.square($scope.number); } }); </script> </body> </html>
AngularJS 指令是扩展的 HTML 属性,带有前缀 ng-。
除了内置的指令以外,
还可以用来创建自定义的标签。它们可以用来装饰元素或者操作DOM属性。
ng-app 指令初始化一个 AngularJS 应用程序。
ng-init 指令初始化应用程序数据。
ng-model 指令把元素值(比如输入域的值)绑定到应用程序。
ng-repeat 指令会重复一个 HTML 元素
Demo6:
<span style="background-color: rgb(255, 255, 51);"><!-- 指定一个AngularJS程序,并初始化 firstName 为 'John' --></span> <div ng-app="" ng-init="firstName='John'"> <p>在输入框中尝试输入:</p> <span style="background-color: rgb(255, 255, 0);"><!-- 将<input/>的输入值绑定到firstName变量 --> </span> <p>姓名:<input type="text" ng-model="firstName"></p> <span style="background-color: rgb(255, 255, 0);"><!-- 输出firstName变量 --></span> <p>你输入的为: {{ firstName }}</p> </div>
其实就是自定义标签
Demo7:
<html> <head> <meta charset="utf-8"> <title>AngularJS Directives(自定义指令)</title> </head> <body> <h2>AngularJS Directives(自定义指令)</h2> <div ng-app="myApp"> <span style="background-color: rgb(255, 255, 0);"><!-- 自定义标签使用 --> </span> <runoob-directive></runoob-directive> </div> <script src="../angular.min.js"></script> <script> var app = angular.module("myApp", []); <span style="background-color: rgb(255, 255, 0);">//使用directive声明标签注意格式遇到大写字母会加【-】 </span> app.directive("runoobDirective", function() { return { template : "<h3>h3大小的自定义指令!</h3>" }; }); </script> </body> </html>
暂时使用不到!当AngularJS的代码量达到一定程度才会用到。
需要使用karma和jasmine来进行ng模块的单元测试.
什么是Karma?
karma是一个单元测试的运行控制框架,提供以不同环境来运行单元测试,比如chrome,firfox,phantomjs等,测试框架支持jasmine,mocha,qunit,是一个以nodejs为环境的npm模块.
什么是jasmine?
jasmine是一个行为驱动开发的测试框架,不依赖任何js框架以及dom,是一个非常干净以及友好API的测试库.
参考教程:
http://www.jb51.net/article/58230.htm