? ? ? ? ?angular框架是三大框架的之一,是比較流行的框架之一。它擴展了css樣式的靜態(tài),融合了web應用的三架馬車。html css ?js 的綜合應用。這樣,就可以幫助我們解決很多問題,優(yōu)化我們的代碼,和性能。大大提高我們的前端的工作效率。三大框架的邏輯是:mvc: mode viewproe contronl 。是模型--視口----控制的編程模式。可以通過mvc模式來實現(xiàn)mode和view來實現(xiàn)分離。
? ? ? ? ?數(shù)據的展示是通過vieproe來進行的,我們可以通過視圖窗口向用戶展示數(shù)據的。mode是我們的數(shù)據集合。可以通過控制臺來進行視圖窗口和數(shù)據的交互。通過angular來進行前端的工作的完整性,也就是說,我們前端的能做到的事情,我們都可以通過angular框架來實現(xiàn)的。所以,angular框架能實現(xiàn)動態(tài)的頁面的實現(xiàn)。使我們的web應用更加富有動態(tài)性。
angular是怎么樣實現(xiàn)我們的代碼的邏輯編寫呢?
? ? ? ? ? ?是通過指令來進行的。也就是說,通過指令來控制我們的業(yè)務邏輯的運行。比如說,我們在架設htm時,需要在html標簽來進行架設,也就是說,html是我們的根標簽。angular就是通過ng-app='',這條指令來進行選擇我們的v層的根標簽。一般是選擇我們的body標簽或者是html標簽。這個是v層的第一步,來進行我們的展示數(shù)據的范圍。就是通過這條指令:ng-app = "app" ,來進行指定。指定了v層后,我們需要的是創(chuàng)建控制器。就是通過我們的app應用來進行創(chuàng)建服務器。代碼如下:
var app = angular.modle('myapp',[]);
? ? ? ? ? ? ? ?app.controller('myController',function($scope){
? ? ? ? ? ? ? ? // 這個是控制的范圍。通俗的來講是控制器的作用域。$scope不僅僅是簡單的js代碼,而是可以控制數(shù)據的狀態(tài)和變化。要對控制器下的數(shù)據進行操作的話,我們就在這里進行
});
? ? ? ? ? 這個代碼就是來進行創(chuàng)建的控制器,在app應用下,控制器條目可以有多少個控制器,我們可以多指定多個,通過app應用創(chuàng)建多個。這個架構是比較完善的。angular的框架模式算是我們完整的架構起來了。?
首先,我們看看angular的基礎語法的表達式。表達式是有語句來組成的,也是我們的基本賦值的語法。不同的模板和框架 有不同的表達式,語法是不一樣的。angular的表達式語法是通過{{}} 如圖所示:
? ? ? ? angular的常用命令;為甚要研究angular的常用命令呢?因為angular框架是通過指令來進行操作數(shù)據的,這是angular最大的特點。通過指令來進行。所以,angular的表達式結合angular的指令來進行完整的操作。第一的常用的指令是變量的命名聲明指令。如同所示:
1:變量的命名:通過ng-init指令來進行聲明。
變量的命名最好在控制臺進行!!原因是避免變量的僵化!!這里只是用ng-init來進行變量的聲明。
2:遍歷的指令:ng-repeat 來進行數(shù)組,類數(shù)組,對象的遍歷,取回我們想要的值。而且,是分別創(chuàng)建所對應的標簽來進行拼接到文檔流中。使用場景,我們可以自然想到的是ajax請求下來的json數(shù)據進解析,拼接到文檔流中。這個是ng-repeat的使用技術場景。所以,我們要使用這個指令來進行解析json數(shù)據。具體的寫法如下:
如果,我們需要數(shù)組,類數(shù)組,下標的話或者是對象的所有的屬性的話,我們可以通過傳不同的參數(shù)來進行。傳一個括號的形式來行。代碼圖如下:
3:ng-class指令來改變元素的class的值,放法有很多種,代碼圖如下:
4:用angular框架來綁定事件。這是我看是體現(xiàn)angular框架的優(yōu)勢。提高性能,不用js DOM節(jié)點的獲取和渲染。直接用ng-事件名來進行綁定。代碼如圖:
? ? ? ? 5:ng-if命令:這個指令是來控制的是我們的所指定的標簽是否來進行渲染。通過條件判斷的來進行的,也是通過布爾值的真假來繼續(xù)判斷的。一般我們可以通過的ng-modle來進行雙向綁定的來進行布爾值的真假的判斷。代碼如下:
6:ng-show/ng-hide:是來判斷元素的顯示和隱藏的指令。使用場景是通過表單驗證或者是提示信息來進行的。如圖所示: