欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

AngularJS實用開發(fā)技巧(推薦)

 更新時間:2016年07月13日 16:39:26   投稿:mrr  
Angular JS 是一組用來開發(fā)Web頁面的框架、模板以及數(shù)據(jù)綁定和豐富UI組件。接下來通過本文給大家介紹AngularJS實用開發(fā)技巧的相關(guān)資料,需要的朋友可以參考下

一、開端

Angular JS 是一組用來開發(fā)Web頁面的框架、模板以及數(shù)據(jù)綁定和豐富UI組件。它提供web應(yīng)用的架構(gòu),無需進行手工DOM操作。 AngularJS很小,只有60K,兼容主流瀏覽器,與jQuery 配合良好。

二、基礎(chǔ)原則了解

①angular的一些入門了解

一、基礎(chǔ)知識

1.angular放棄了IE8

2.四大核心分別是mvc、模塊化、指令系統(tǒng)、雙向數(shù)據(jù)綁定

二、一些原則

1.不要復(fù)用controller,一個控制器一般只負責(zé)一小塊視圖。

2.不要在controller里面操作dom。

3.不要在contorller里面做數(shù)據(jù)格式化,ng有很好的表單控件。

4.不要在controller里面做數(shù)據(jù)過濾操作,有$filter服務(wù)。

5.一般情況下,controller是不會互相調(diào)用的,控制器之間的交互會通過事件進行。

6.angular利用指令來復(fù)用view。

7.$scope是一個樹型結(jié)構(gòu),與DOM標簽平行。

8.子$scope對象會繼承父$scope上的屬性和方法。

9.每一個angular應(yīng)用只有一個$rootScope對象。(一般位于ng-app上)。

10.可以用angular.element($0).scope()進行調(diào)試。

11.使用ngRoute進行視圖之間的路由。

三、HTML頁面最常用且實用的angular內(nèi)置指令

①.ng-class(適用于類似點贊、關(guān)注等某個樣式會因為某個操作改變的情況)

ng-class 指令用于給 HTML 元素動態(tài)綁定一個或多個 CSS 類。ng-class 指令的值可以是字符串,對象,或一個數(shù)組。

如果是字符串,多個類名使用空格分隔。

如果是對象,需要使用 key-value 對,key 是一個布爾值,value 為你想要添加的類名。只有在 key 為 true 時類才會被添加。

如果是數(shù)組,可以由字符串或?qū)ο蠼M合組成,數(shù)組的元素可以是字符串或?qū)ο蟆?br />

建議的兩種使用方式:

一、字符串形式,代碼如下:

<i class="icon" ng-class="{true:'ion-ios-heart',false:'ion-ios-heart-outline'}[AccountInfo.isFocus]" ng-click='wetherFocus()'>
</i>

這樣的意思就是,i標簽有一個基礎(chǔ)類為icon,ng-class則綁定了一個動態(tài)的類,而這個類要取哪一個值則由AccountInfo.isFocus的值是true或者false來決定,若其值為true則i標簽會添加ion-ios-heart這個類,若其值為false則i標簽會添加ion-ios-heart-outline

這個類。i標簽還綁定了一個ng-click的事件,在這個事件里面除了處理相應(yīng)的邏輯之外,還決定AccountInfo.isFocus的值。這樣的話,當發(fā)生點擊操作的時候,自然就改變i標簽相應(yīng)的類,繼而表現(xiàn)出不同的樣式了。

二、key-value的樣式,代碼如下:

<i class="icon" ng-class="{'ion-ios-heart':isIos,'ion-android-heart':isAndroid}"> </i>

顯然,由代碼則可以看出,這樣的含義就是當isIos為true的時候就會取ion-ios-heart這個類,當isAndroid的值為true的時候,就會取ion-android-heart這個類。

②.ng-show和ng-hide(適用于對于不同的情況顯示兩種不同的內(nèi)容時) 

ng-show 指令在表達式為 true 時顯示指定的 HTML 元素,否則隱藏指定的 HTML 元素。

ng-hide 指令在表達式為 true 時隱藏指定的 HTML 元素,否則顯示指定的 HTML 元素。

哈哈,看著就是水火不容的兄弟。。。。

例子如下:

<div class="keyboard">
<span class="keyboardIcon" ng-click="toggleMenu()"></span>
</div>
<div class="footer-menu">
<ul class="menu-list" ng-show="menuState">
...
</ul>
<div class="footer-send" ng-hide="menuState">
...
</div>

設(shè)置一個布爾變量menuState(實際開發(fā)中你可以用表達式,三目運算式等等),當其為true的時候,ng-show的內(nèi)容會顯示,ng-hide的內(nèi)容會隱藏。反之則反之。。。

③.ng-switch(適用于在多種情況下顯示不同的內(nèi)容時)

ng-switch 指令根據(jù)表達式顯示或隱藏對應(yīng)的部分。

對應(yīng)的子元素使用 ng-switch-when 指令,如果匹配選中選擇顯示,其他為匹配的則移除。

通過使用 ng-switch-default 指令設(shè)置默認選項,如果都沒有匹配的情況,默認選項會顯示。

例子:

<div ng-switch="essayType">
<div class="list-cart" ng-switch-when="4">
....
</div>
<div class="list-cart left-pic" ng-switch-when="3">
....
</div>
<div class="single-pic" ng-switch-when="1">
...
</div>
<div class="single-pic" ng-switch-when="2">
...
</div>
<div class="single-pic" ng-switch-default>
...
</div>
</div>

④.ng-model(這里主要說一下ng-model神奇的小坑坑)

ng-model 指令綁定了 HTML 表單元素到 scope 變量中。

如果 scope 中不存在變量, 將會創(chuàng)建它。ng-model常用于<input>, <select>, <textarea>等元素。

如下代碼:

<div class="WhatISay">
<textarea name="my-massage-detail" ng-model="content" class="my-massage-detail" placeholder="請輸入留言">
</textarea>
<a class="button btn"ng-click="submitMes()">提交</a><br></div>

按照定義,理論上來說我們提交的時候,直接在controller里面獲取在頁面定義了的ng-model的值,是可以的。但是實際上這樣是不可行的。親測發(fā)現(xiàn)輸出了一個undefined,而且,如果在controller里面定義ng-model的初始值的話,獲取到的就是初始值而不是改變后的最新值。

查找了一些資料,大概意思就是說。angular限制了我們的一些定義。我們只能使用一個非原始的對象來傳遞參數(shù)。

什么意思呢。稍微改一下上面的例子,如下:

html代碼:

<div class="WhatISay">
<textarea name="my-massage-detail" ng-model="model.content" class="my-massage-detail" placeholder="請輸入留言">
</textarea>
<a class="button btn"ng-click="submitMes()">提交</a>
</div>

controller代碼:

$scope.model = {};
$scope.model.content = '';
$scope.submitMes=function(){
console.log($scope.model.content);
}

就是我們是定義了一個對象,然后把ng-model定義為這個對象里面的一個屬性這樣來處理的。這樣子,我們就得到了ng-model的最新值了。

還有一種比較簡單的方式就是直接把ng-model作為參數(shù)傳進去就好了。

例子如下:

//HTML代碼
<input type="text" ng-model="code">
<button ng-click="setCode(code)">Login</button><br>
//controller代碼
$scope.setCode = function(code){
alert(code);
}

四、數(shù)據(jù)交互實用技巧

①Promise的利用

ES6定義了Promise對象。這個對象挺好用的,特別是用在與后臺交互的時候。既預(yù)防回調(diào)過深,又可以針對一些情況做統(tǒng)一處理,還提高了代碼的可讀性。在angularJs里面也封裝了這樣一個服務(wù),就是$q。

$q是做為angularjs的一個服務(wù)而存在的,只是對promise異步編程模式的一個簡化實現(xiàn)版。defer對象(延遲對象)可以通$q.defer()獲取,該對象有三個方法:

resolve(value):向promise對象異步執(zhí)行體發(fā)送消息告訴他我已經(jīng)成功完成任務(wù),value即為發(fā)送的消息。

reject(value): 向promise對象異步執(zhí)行體發(fā)送消息告訴他我已經(jīng)不可能完成這個任務(wù)了,value即為發(fā)送的消息。

notify(value): 向promise對象異步執(zhí)行體發(fā)送消息告訴他我現(xiàn)在任務(wù)完成的情況,value即為發(fā)送的消息。

  這些消息發(fā)送完promise會調(diào)用現(xiàn)有的回調(diào)函數(shù)。

promise即與這個defer對象的承諾對象。promise對象可以通過defer.promise獲取,promise對象的一些方法:

  then(successCallback,errorCallback,notifyCallback):參數(shù)為不同消息下的不同回調(diào)函數(shù),defer發(fā)送不同的消息執(zhí)行不同的回調(diào)函數(shù),消息作為這些回調(diào)函數(shù)的參數(shù)傳遞。返回值為回一個promise對象為支持鏈式調(diào)用而存在。當?shù)谝粋€defer對象發(fā)送消 息后,后面的promise對應(yīng)的defer對象也會發(fā)送消息,但是發(fā)送的消息不一樣,不管第一個defer對象發(fā)送的是reject還是resolve,第二個及其以后的都是發(fā)送的resolve,消息是可傳遞的。

  catch(errorCallback):then(null,errorCallback)的縮寫。

  finally(callback):相當于then(callback,callback)的縮寫,這個finally中的方法不接受參數(shù),卻可以將defer發(fā)送的消息和消息類型成功傳遞到下一個then中。

  defer():用來生成一個延遲對象 var defer =$q.defer();

  reject():參數(shù)接收錯誤消息,相當于在回調(diào)函數(shù)中拋出一個異常,然后在下一個then中調(diào)用錯誤的回調(diào)函數(shù)。

  all():參數(shù)接收為一個promise數(shù)組,返回一個新的單一promise對象,當這些promise對象對應(yīng)defer對象全部解決這個單一promise對象才會解決,當這些promise對象中有一個被reject了,這個單一promise同樣的被reject了。

  when():接收第一個參數(shù)為一個任意值或者是一個promise對象,其他3個同promise的then方法,返回值為一個promise對象。第一個參數(shù)若不是promise對象則直接運行success回調(diào)且消息為這個對象,若為promise那么返回的promise其實就是對這個promise 類型的參數(shù)的一個包裝而已,被傳入的這個promise對應(yīng)的defer發(fā)送的消息,會被我們when函數(shù)返回的promise對象所接收到。

具體用法如下:

在angular中,定義一個專門用來交互的服務(wù)。

get: function (url, options) { <br> var deferred = $q.defer(); <br> showTip();
$http.get(url, options).success(function (data) {
hideTip();
if (data.Success) {
deferred.resolve(data);
} else {
deferred.reject(data.Message);
}
}).error(function (data) {
hideTip();
deferred.reject(data);
});
return deferred.promise;
}
//controller里面的調(diào)用
get('url',params)
.then(function (data) {
//這里是successCallback
},function (data) {
//這里是errorCallback
});

  這樣,我們就可以在每個請求發(fā)出時統(tǒng)一定義一些提示,然后請求結(jié)束之后隱藏這些提示。這段代碼中,大概意思就是,當請求成功的時候,就會調(diào)用deferred.resolve(data),把狀態(tài)設(shè)置為成功,這樣就會自動執(zhí)行then里面的第一個函數(shù)即successCallback,并把請求到的數(shù)據(jù)data傳遞進去。而當請求失敗的時候,則會調(diào)用第二個函數(shù),即errorCallback。

以上所述是小編給大家介紹的AngularJS實用的開發(fā)技巧,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Angular.js實現(xiàn)注冊系統(tǒng)的實例詳解

    Angular.js實現(xiàn)注冊系統(tǒng)的實例詳解

    Angular.js是Google開發(fā)的前端技術(shù)框架,最近一直在學(xué)習(xí)Angular.js,通過對angular.js的簡單理解后發(fā)現(xiàn),angular.js通過一些簡單的指令即可實現(xiàn)對DOM元素的操作,其特色為雙向數(shù)據(jù)綁定,下面這篇文章給大家詳細介紹Angular.js實現(xiàn)注冊系統(tǒng)的方法,一起來看看吧。
    2016-12-12
  • angular父子組件通信詳解

    angular父子組件通信詳解

    這篇文章主要為大家介紹了angular父子組件通信,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • 利用Angular2的Observables實現(xiàn)交互控制的方法

    利用Angular2的Observables實現(xiàn)交互控制的方法

    這篇文章主要介紹了利用Angular2的Observables實現(xiàn)交互控制的方法,我們主要針對一些在跟服務(wù)器端交互的時候遇到的問題,來看看Observable給我們帶來的特性。感興趣的可以了解一下
    2018-12-12
  • AngularJS中關(guān)于ng-class指令的幾種實現(xiàn)方式詳解

    AngularJS中關(guān)于ng-class指令的幾種實現(xiàn)方式詳解

    這篇文章給大家介紹了angularJS中ng-class指令的三種實現(xiàn)方式,其中包括通過數(shù)據(jù)的雙向綁定、通過對象數(shù)組和通過key/value這三種方式,有需要的朋友們可以參考學(xué)習(xí),下面來一起看看吧。
    2016-09-09
  • Angular2 多級注入器詳解及實例

    Angular2 多級注入器詳解及實例

    這篇文章主要介紹了Angular2 多級注入器詳解的相關(guān)資料,并附簡單實例代碼,需要的朋友可以參考下
    2016-10-10
  • angular 基于ng-messages的表單驗證實例

    angular 基于ng-messages的表單驗證實例

    本篇文章主要介紹了angular 基于ng-messages的表單驗證實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • Angular2 父子組件通信方式的示例

    Angular2 父子組件通信方式的示例

    本篇文章主要介紹了Angular2 父子組件通信方式的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Angular整合zTree的示例代碼

    Angular整合zTree的示例代碼

    本篇文章主要介紹了Angular整合zTree的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Angularjs修改密碼的實例代碼

    Angularjs修改密碼的實例代碼

    這篇文章主要介紹了Angularjs修改密碼的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • 微信小程序?qū)崿F(xiàn)左右聯(lián)動的實戰(zhàn)記錄

    微信小程序?qū)崿F(xiàn)左右聯(lián)動的實戰(zhàn)記錄

    聯(lián)動菜單是大家在開發(fā)小程序經(jīng)常會遇到的一個功能,下面這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)左右聯(lián)動的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評論