Promises是一種令程式碼異步行為更優雅的抽象,它很有可能是JavaScript的下一個程式設計範式,一個Promise即表示任務結果,無論該任務是否完成。
在一些現代瀏覽器中已經提供了原生的Promise對象,其遵循Promise/A 標準。在jQuery1.5 ,提供了$.Deferred(其可以被轉換為promise物件)。在許多知名的框架中,也提供了promise物件。 promise物件在javascript中已經是一種很重要的模式,它在解決非同步問題時所表現出的優雅,正是javascript所需要的。以下以jQuery中的$.Deferred物件為例,來看看promise物件是如何處理非同步問題。關於$.Deferred對象,可以到jQuery官網查看,這裡就不贅述了。
一、封裝非同步操作
首先,我們以載入圖片為例,看以下程式碼:
//加载图片函数 var loadImg = function(url){ var img = new Image() , deferred = $.Deferred() ; img.src = url ; img.onload = function(){ //成功则触发deferred.resolve deferred.resolve( this ) ; } ; img.onerror = function(e){ //失败则触发deferred.reject deferred.reject( e ); } ; //返回promise对象 return deferred.promise() ; } ; //请求图片 var request = loadImg('http://r2.ykimg.com/0515000054AFFC2D6737B343930AFAD6') ; //请求成功 request.done(function(img){ //code }) ; //可以注册多个回调,当请求成功时,会按注册的顺序执行,fail和always也有此性质 request.done(function(img){ // code }); //请求失败 request.fail(function(){ // code }) ; //请求完毕 request.always(function(){ //code });
以上的程式碼,我封裝了圖片載入的操作,將他們委託給$.Deferred,最後產生一個promise回傳。使用這樣的方式,相較於用對外暴露回調的方式,顯得更乾淨、更清晰。這麼做的另一個更重要的原因是,promise的連結。
二、promise的連接
我們還是以上面圖片載入的程式碼為例,來看看如何做promise的連接,看以下程式碼:
var request = loadImg('http://b1.hucdn.com/upload/item/1411/13/89613257775992_800x800.jpg') ; request.done(function(img){ //code }) ; //request连接别的promise之后返回的promise var request3 = request.then(function(img){ //request执行成功时 连接request1 var request1 = loadImg('http://b1.hucdn.com/upload/item/1410/19/29492535741725_800x800.jpg') ; return request1 ; },function(e){ //request执行失败时 连接request2 var request2 = loadImg('http://b1.hucdn.com/upload/item/1410/19/29492535741725_800x800.jpg') ; return request2 ; }); //request执行并且request1或request2成功执行时 request3.done(function(done){ //code }) ;
promise物件提供了then的方法,它接受兩個回呼:onResolve和onReject,在回呼中返回promise,就可以完成promise之間的連接。透過這種方式,可以使非同步操作串列的執行。
同時,jQuery也提供了另一種連接方式,看程式碼:
var request = loadImg('http://b1.hucdn.com/upload/item/1412/23/48188827139381_800x800.jpg') ; var request1 = loadImg('http://b1.hucdn.com/upload/item/1412/06/50258594673502_800x800.jpg') ; //通过$.when连接promise var request2 = $.when(request,request1) ; request2.done(function(img,img){ //code }) ;
jQuery中提供了$.when這個函數,它可以接受n個promise物件為參數,它是將promise的執行結果連接在一起。使用這種方式,多個非同步操作可以並行執行。
三、The End
這裡的程式碼是以載入圖片為例,同樣的做法可以應用到其他的非同步操作中去。例如jQuery中的$.ajax、$.fn.animate,呼叫它們回傳的就是promise。在node端,也可以把一些非同步操作(讀取資料庫、讀取檔案等)封裝成promise。繼而對多個promise實現合併的操作,使其串列或並行執行。
附:deferred物件
deferred除了用來轉換promise物件外,本身也是個很有用的物件。它除了提供像promise物件的那些方法和屬性外,還有notify函數和progress函數,這兩個函數在實現進度條和瀑布流的時候,有很大的用處。
在實現進度條時,resolve和done函數可以用來定義進度條讀取到100%時的觸發時機和觸發邏輯,notify和progress函數可以用來定義進度條在讀取中的觸發時機和觸發邏輯。 reject和fail函數可以用來定義進度讀取失敗時的觸發時機和觸發邏輯。
在實現瀑布流時,resolve和done函數可以用來定義當資料已經全部載入到頁面的觸發時機和觸發邏輯,notify和progress函數可以用來定義瀑布流讀取下一頁的觸發時機和觸發邏輯。

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何

數據集對於構建API模型和各種業務流程至關重要。這就是為什麼導入和導出CSV是經常需要的功能。在本教程中,您將學習如何在Angular中下載和導入CSV文件


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3漢化版
中文版,非常好用

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能