AngularJS中處理多個(gè)promise的方式
在使用AngularJS中處理promise的時(shí)候,有時(shí)會(huì)碰到需要處理多個(gè)promise的情況。
最簡單的處理就是每個(gè)promise都then。如下:
var app = angular.module("app",[]); app.controller("AppCtrl", function($q. $timeout){ var one = $q.defer(); var two = $q.defer(); var three = $q.defer(); $timeout(function(){ one.resolve("one done"); }, Math.random() * 1000) $timeout(function(){ two.resolve("two done"); }, Math.random() * 1000) $timeout(function(){ three.resolve("three done"); }, Math.random() * 1000) functioin success(data){ console.log(data); } one.promise.then(success); two.promise.then(success); three.promise.then(success); })
有沒有更好的方式?
$q.all方法可以接受promise的一個(gè)數(shù)組,按如下調(diào)用:
var all = $q.all([one.promise, two.promise, three.promise]); all.then(success);
什么是promise?
promise是一種用異步的方式處理值的方法,promise是對象,代表了一個(gè)函數(shù)最終可能的返回值或者拋出的異常,在與遠(yuǎn)程對象打交道時(shí)我們可以把他看作是遠(yuǎn)程對象的一個(gè)代理。 如果說是promise也是異步處理方式的一種,那么我們會(huì)想起它和XHR和$.ajax有啥區(qū)別呢?
習(xí)慣上js使用閉包或者回調(diào)來相應(yīng)非同步返回的數(shù)據(jù),比如頁面加載之后的XHR請求。我們可以跟數(shù)據(jù)進(jìn)行正常交互,就好像它已經(jīng)返回了一樣,而不需要依賴回調(diào)函數(shù)的觸發(fā)。
那么ng提出的promise是為了解決什么問題呢? 回調(diào)已經(jīng)被使用了很長時(shí)間,通常如果有回調(diào)依賴其他還回調(diào)時(shí)將會(huì)時(shí)調(diào)試變得非常艱難,每一步調(diào)用之后都需要顯示處理錯(cuò)誤。與之不同的是promise提供了另外一個(gè)抽象:這些函數(shù)返回promise對象。
為什么使用promise
使用了promise的收獲之一是逃脫了回調(diào)的固定思維邏輯。promise讓異步處理的機(jī)制看上去更像是同步,基于同步函數(shù)我們可以按照預(yù)期來捕獲返回值和異常值??梢栽诔绦蛑械娜魏螘r(shí)刻捕捉錯(cuò)誤,并且繞過依賴于程序異常的后續(xù)代碼,我們不需要思考這個(gè)同步帶來的好處。因此使用promise的目的是:獲取功能組合和錯(cuò)誤冒泡能力的同時(shí),保持代碼異步運(yùn)行的能力。
promise是頭等對象,自帶了一些約定。
• 只有一個(gè)resolve或者reject會(huì)被調(diào)用到。
• 如果promise被執(zhí)行或者被拒絕了,依賴于他們的處理程序仍然會(huì)被調(diào)用。
• 處理程序總是會(huì)被異步調(diào)用。
相關(guān)文章
AngulaJS路由 ui-router 傳參實(shí)例
本篇文章主要介紹了AngulaJS路由 ui-router 傳參實(shí)例 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04Angular性能優(yōu)化之第三方組件和懶加載技術(shù)
這篇文章主要介紹了Angular性能優(yōu)化之第三方組件和懶加載技術(shù),對性能優(yōu)化感興趣的同學(xué),可以參考下2021-05-05AngularJS基礎(chǔ) ng-hide 指令用法及示例代碼
本文主要介紹AngularJS ng-hide 指令,這里整理了ng-hide指令的基礎(chǔ)資料,并附實(shí)例代碼,有興趣的小伙伴參考下2016-08-08詳解使用angular框架離線你的應(yīng)用(pwa指南)
這篇文章主要介紹了詳解使用angular框架離線你的應(yīng)用(pwa指南),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01Angular實(shí)現(xiàn)form自動(dòng)布局
這篇文章主要介紹了Angular實(shí)現(xiàn)form自動(dòng)布局的相關(guān)資料,以代碼片段的形式分析了Angular實(shí)現(xiàn)form自動(dòng)布局的實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下2016-01-01AngularJS解決ng-if中的ng-model值無效的問題
本篇文章主要介紹了AngularJS解決ng-if中的ng-model值無效的問題,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06AngularJS使用angular.bootstrap完成模塊手動(dòng)加載的方法分析
這篇文章主要介紹了AngularJS使用angular.bootstrap完成模塊手動(dòng)加載的方法,結(jié)合實(shí)例形式分析了angular.bootstrap函數(shù)手動(dòng)加載模塊的步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-01-01