中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

AngularJS實用開發技巧(推薦)
來源:易賢網 閱讀:1071 次 日期:2016-07-27 15:53:02
溫馨提示:易賢網小編為您整理了“AngularJS實用開發技巧(推薦)”,方便廣大網友查閱!

一、開端

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

二、基礎原則了解

①angular的一些入門了解

一、基礎知識

1.angular放棄了IE8

2.四大核心分別是mvc、模塊化、指令系統、雙向數據綁定

二、一些原則

1.不要復用controller,一個控制器一般只負責一小塊視圖。

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

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

4.不要在controller里面做數據過濾操作,有$filter服務。

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

6.angular利用指令來復用view。

7.$scope是一個樹型結構,與DOM標簽平行。

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

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

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

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

名單

三、HTML頁面最常用且實用的angular內置指令

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

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

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

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

如果是數組,可以由字符串或對象組合組成,數組的元素可以是字符串或對象。

建議的兩種使用方式:

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

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

</i>

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

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

二、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(適用于對于不同的情況顯示兩種不同的內容時)

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>

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

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

ng-switch 指令根據表達式顯示或隱藏對應的部分。

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

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

例子:

<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 中不存在變量, 將會創建它。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的值,是可以的。但是實際上這樣是不可行的。親測發現輸出了一個undefined,而且,如果在controller里面定義ng-model的初始值的話,獲取到的就是初始值而不是改變后的最新值。

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

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

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作為參數傳進去就好了。

例子如下:

//HTML代碼

<input type="text" ng-model="code">

<button ng-click="setCode(code)">Login</button><br>

//controller代碼

$scope.setCode = function(code){

alert(code);

}

四、數據交互實用技巧

①Promise的利用

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

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

resolve(value):向promise對象異步執行體發送消息告訴他我已經成功完成任務,value即為發送的消息。

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

notify(value): 向promise對象異步執行體發送消息告訴他我現在任務完成的情況,value即為發送的消息。

這些消息發送完promise會調用現有的回調函數。

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

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

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

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

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

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

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

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

具體用法如下:

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

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里面的調用

get('url',params)

.then(function (data) {

//這里是successCallback

},function (data) {

//這里是errorCallback

});

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

以上所述是小編給大家介紹的AngularJS實用的開發技巧

更多信息請查看網絡編程
易賢網手機網站地址:AngularJS實用開發技巧(推薦)
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美在线看片| 国产综合婷婷| 国产精品专区h在线观看| 伊人久久成人| 欧美国产乱视频| 一区二区三区波多野结衣在线观看| 免费一区二区三区| 亚洲精品一区二区三区婷婷月| 欧美日韩精品三区| 欧美亚洲视频在线观看| 国内精品伊人久久久久av一坑| 欧美日韩伦理在线免费| 亚洲已满18点击进入久久| 国产精品永久在线| 欧美不卡视频| 午夜精品久久久久久久99黑人| 韩国在线一区| 欧美日韩国产限制| 欧美专区在线观看| 亚洲精品久久久久中文字幕欢迎你| 国产精品香蕉在线观看| 欧美国产视频在线观看| 欧美在线亚洲| 在线亚洲精品福利网址导航| 国内精品一区二区三区| 欧美午夜精品一区| 免费成人高清在线视频| 亚洲欧美日韩精品综合在线观看| 亚洲国产91| 国产一区白浆| 国产精品久久久久一区二区| 欧美大片免费观看| 久久精品99国产精品日本| 99在线热播精品免费| 亚洲高清免费| 亚洲一区高清| 亚洲日本欧美在线| 国内精品久久久久久久影视麻豆| 欧美色123| 欧美日韩国产免费| 嫩模写真一区二区三区三州| 久久都是精品| 欧美一区视频| 性欧美8khd高清极品| 亚洲——在线| 亚洲欧美欧美一区二区三区| 亚洲视频福利| 在线一区视频| 99re在线精品| av不卡在线| 一本久道久久综合婷婷鲸鱼| 亚洲精品乱码久久久久| 亚洲欧洲精品一区二区三区波多野1战4 | 一色屋精品亚洲香蕉网站| 国产精品推荐精品| 国产精品拍天天在线| 国产精品国产三级国产| 欧美调教vk| 国产精品日本| 国产性猛交xxxx免费看久久| 国产欧美va欧美va香蕉在| 国产精品视频一区二区高潮| 国产欧美日韩在线视频| 国产一区二区你懂的| 国产欧美日韩精品a在线观看| 国产欧美精品日韩| 国产日韩一级二级三级| 国产在线精品一区二区夜色| **网站欧美大片在线观看| 1024亚洲| 一区二区欧美国产| 亚洲综合第一| 久久一区二区三区国产精品| 每日更新成人在线视频| 欧美极品一区二区三区| 欧美日韩在线直播| 国产精品伦一区| 国产一区二区高清不卡| 在线精品视频免费观看| 亚洲精品国久久99热| 宅男噜噜噜66一区二区66| 先锋亚洲精品| 欧美大色视频| 国产精品人人做人人爽人人添| 国产一区在线播放| 日韩天堂在线视频| 久久经典综合| 欧美三级小说| 亚洲自拍另类| 久久久久久色| 欧美日韩亚洲一区二区三区四区| 国产欧美视频一区二区| 在线成人国产| 亚洲免费影视第一页| 毛片一区二区| 国产免费成人| 亚洲色图制服丝袜| 欧美ed2k| 好吊色欧美一区二区三区四区| 一区二区三区欧美亚洲| 麻豆精品视频在线观看| 国产欧美精品va在线观看| 在线视频日本亚洲性| 蜜桃久久精品乱码一区二区| 欧美午夜一区| 亚洲国产精品久久久久婷婷884| 亚洲欧美影院| 欧美日韩一区视频| 亚洲欧洲日本国产| 久久久之久亚州精品露出| 国产精品乱码一区二三区小蝌蚪| 亚洲精品视频免费| 久久国产乱子精品免费女| 国产精品美女久久久| 一区二区三区精品| 欧美精品一区二| 亚洲日本久久| 欧美精彩视频一区二区三区| 精品999网站| 久久精品青青大伊人av| 国产欧美一区二区精品性| 亚洲视频一区二区免费在线观看| 欧美精品在线观看| 亚洲国产精品va| 久久综合五月| 在线免费观看日本欧美| 久久一区二区精品| 一区二区视频在线观看| 久久久久久综合| 韩国av一区二区三区四区| 欧美在线视频在线播放完整版免费观看| 国产精品国色综合久久| 亚洲手机在线| 国产精品一区一区| 先锋影音网一区二区| 国产精品夜夜夜| 欧美在线一区二区三区| 国产视频在线观看一区| 欧美在线观看视频一区二区三区| 国产欧美精品va在线观看| 性欧美video另类hd性玩具| 国产精品拍天天在线| 欧美一区二区三区视频免费播放| 国产精品视频不卡| 欧美一区二区视频观看视频| 国产一区二区三区久久悠悠色av | 欧美在线免费视屏| 国产精品伊人日日| 性色av一区二区怡红| 一区二区免费看| 欧美三日本三级少妇三2023| 一区二区三欧美| 国产精品欧美一区喷水| 久久精品毛片| 亚洲精华国产欧美| 欧美日韩美女一区二区| 午夜久久福利| 亚洲国产日日夜夜| 国产精品久久久91| 久久一区二区三区四区| 亚洲精品视频中文字幕| 国产伦精品一区二区三区高清版| 久久福利毛片| 一本色道久久综合| 国产亚洲免费的视频看| 欧美激情小视频| 欧美一级在线视频| 亚洲三级视频| 国产三区二区一区久久| 欧美精品1区2区| 亚洲男人第一网站| 亚洲九九精品| 狠狠久久五月精品中文字幕| 欧美天堂亚洲电影院在线播放 | 国产精品久久久久三级| 久久色在线播放| 亚洲欧美日韩网| 亚洲精品欧美日韩专区| 国产一区二区三区不卡在线观看| 欧美日本一区| 麻豆精品传媒视频| 午夜精品亚洲一区二区三区嫩草| 亚洲人成高清| 精品成人一区二区| 国产精品v日韩精品v欧美精品网站| 开心色5月久久精品| 性色av一区二区怡红| 一本色道久久综合亚洲91| 尤物99国产成人精品视频| 国产精品久久久久久久久久三级| 欧美成人网在线| 久久综合免费视频影院| 久久精品91久久久久久再现| 亚洲一区久久久| 一区二区三区欧美在线| 亚洲乱亚洲高清| 亚洲黄一区二区三区| 在线观看亚洲视频| 一区二区三区在线免费观看| 国产区亚洲区欧美区|