AngularJS 學習教程

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) MVVMMoodel-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>

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>

MVVMMoodel-View-ViewModel

MVVM模式是Model-View-ViewMode(模型-視圖-視圖模型)模式的簡稱,其最早出現在微軟的WPFSilverlight框架中。MVVM模式利用框架內置的雙向綁定技術對MVPModel-View-Presenter)模式的變型,引入了專門的ViewModel(視圖模型)來實現ViewModel的粘合,讓ViewModel的進一步分離和解耦。

雙向綁定確實非常使用,通過封裝雙向綁定中間加了一個概念層ViewMode

個人感覺跟jquerymvc基本類似,只不過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>

Directives指令

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的代碼量達到一定程度纔會用到。

需要使用karmajasmine來進行ng模塊的單元測試.

 

什麼是Karma

karma是一個單元測試的運行控制框架,提供以不同環境來運行單元測試,比如chrome,firfox,phantomjs,測試框架支持jasmine,mocha,qunit,是一個以nodejs爲環境的npm模塊.

 

什麼是jasmine

jasmine是一個行爲驅動開發的測試框架,不依賴任何js框架以及dom,是一個非常乾淨以及友好API的測試庫.

 

參考教程:

http://www.jb51.net/article/58230.htm




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章