成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript異步調用框架問題描述

開發 前端
本文描述了對JavaScript異步調用的需求,一些現存的問題以及背景介紹。在Ajax應用中,調用XMLHttpRequest是很常見的情況。然而在單線程的JavaScript編程中,XHR異步調用的代碼風格實在是與一般的JavaScript代碼格格不入。

問題

在Ajax應用中,調用XMLHttpRequest是很常見的情況。特別是以客戶端為中心的Ajax應用,各種需要從服務器端獲取數據的操作都通過XHR異步調用完成。然而在單線程的JavaScript編程中,XHR異步調用的代碼風格實在是與一般的JavaScript代碼格格不入。這樣就產生了對JavaScript異步調用的需求。

額外參數

考慮一個除法函數,如果它是純客戶端的同步函數,那么簽名會是這樣的:

function divide(operand1, operand2)

然而假設我們對客戶端除法的精度不滿意,于是把除法轉移到服務器端來執行,那么它是個需要調用XHR的異步函數,簽名也就可能會是以下幾種之一:

function divide(operand1, operand2, callback)

function divide(operand1, operand2, successCallback, failureCallback)

function divide(operand1, operand2, options)

我們必須在簽名中引入新的參數來傳遞回調函數,不能選擇讓函數變成阻塞式的同步調用。

可傳遞性

不僅僅直接操作XHR的函數需要引入新的參數,這種復雜性還會順著調用棧向外傳遞。例如說,我們對加減乘除四則運算作了封裝,只向外暴露一個運算接口:

function calculate(operand1, operand2, operator)

這個calculate函數根據operator參數來調用內部的plus, subtract, multiply, divide函數。然而,因為divide函數變成了異步函數,所以整個calculate函數不得不也轉變為異步函數:

function calculate(operand1, operand2, operator, callback)

同時,在調用棧之上凡是需要調用到calculate的函數,都必須變成異步的,除非它并不需要向上一級調用函數返回結果。

同步并存

盡管calculate函數變成了一個異步函數,它所調用的plus, subtract, multiply函數還是同步函數,只有調用divide時是異步的,這時候calculate就是一個異步同步并存函數。

這會帶來什么問題?calculate的調用者看到函數簽名自然會認為calculate是個異步函數,因為它需要傳遞回調函數,然而calculate的執行方式卻是不確定的。考慮如下調用:

calculate(operand1, operand2, operator, callback);

next();

這里涉及到callback和next兩個函數,它們哪個先執行哪個后執行是不確定的,或者說是依賴于calculate具體實現的。

如果calculate的實現是,當不需要進行異步操作時,直接調用callback。那么,在執行加減乘法時callback會在next之前被調用;在執行除法時next會在callback之前調用。

如果我們不喜歡這種不確定性,我們可以改變一下calculate的實現,把同步調用也都改為setTimeout形式的,這樣在任何情況下next都一定會在callback之前被調用。

然而后面一種做法依賴于成本較高的實現方式,開發者一個不小心(或者擺明偷懶)就會漏掉setTimeout,導致函數調用順序變得不確定,所以我們會希望這是框架幫助實現的功能,在使用框架時無法把這繞過。這些都指向對JavaScript異步調用的需求。

場景

在這里,我舉一個關于上述問題的具體應用場景。(為簡化問題,描述已略作修改,與實際應用并不一致。)

在百度Hi網頁版里面,我們會在客戶端保存一個用戶對象列表,在打開和這個用戶的聊天窗口時,我們需要從中讀取這個用戶的信息。這個操作就涉及很多可能同步又可能異步的分支:

◆用戶對象未緩存

◆異步讀取用戶信息

◆用戶對象已緩存

◆用戶是好友(信息更新會由服務器端推送)

◆同步讀取用戶信息

◆用戶不是好友(信息更新需要由客戶端拉取)

◆可以接受緩存信息

◆同步讀取用戶信息

◆必須獲取最新信息

◆異步讀取用戶信息

可以看到,分支的結果最終既有同步的,也有異步的。并且這些分支還不是在一個函數里完成,而是在幾個函數里實現。也就是說,按照傳統的模式,這些函數一部分是同步的,一部分是異步的,由于異步的傳遞性,最終調用棧頂層的函數都是異步的。

為了解決這個問題,我們需要寫一個JavaScript異步調用框架,用一種統一的方式來進行調用,把同步和異步調用都合并為一種返回方式。

【編輯推薦】

  1. 淺談如何用Javascript+VML實現流程設計器
  2. 常用的JavaScript驗證正則表達式
  3. 給JavaScript初學者的24個小竅門
  4. JavaScript中關于Cookie的詳細介紹
  5. JavaScript中confirm,alert,prompt的用法
責任編輯:yangsai 來源: Cat in dotNET
相關推薦

2009-07-01 14:05:23

JavaScript異

2009-07-01 14:37:14

JavaScript異

2009-07-01 14:23:46

JavaScript異

2009-07-01 14:31:01

JavaScript異

2009-10-20 16:48:30

C#委托

2009-11-09 10:50:30

WCF異步調用

2009-12-21 14:10:26

WCF異步調用

2009-11-06 15:54:15

WCF異步調用

2009-12-07 14:35:42

WCF異步調用

2010-01-11 17:24:19

VB.NET異步調用

2011-03-02 08:57:22

jQueryJavaScript

2012-10-29 10:59:27

Windows 8

2009-12-07 14:26:47

WCF異步調用

2021-03-29 09:26:44

SpringBoot異步調用@Async

2010-02-22 13:28:05

WCF異步調用

2009-08-21 11:24:16

C#異步調用

2024-07-31 15:57:41

2024-10-15 10:28:43

2009-08-20 19:08:30

C#異步調用

2022-07-01 08:14:28

Dubbo異步代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品久久久久久首妖 | 中文字幕亚洲欧美日韩在线不卡 | 成人精品在线观看 | 国产精品视频不卡 | 久久久精品一区二区三区 | 黄色大片免费网站 | 亚洲精品久久久久久久不卡四虎 | 国产精品国产三级国产播12软件 | 九九热精品视频 | 欧美一区二区在线视频 | 天天操狠狠操 | 亚洲一区二区三 | 狠狠爱免费视频 | 国产精品一区二区免费 | 久久精品一二三影院 | 亚洲第一在线 | 一级免费看| 国产精品久久久久久婷婷天堂 | 国家aaa的一级看片 h片在线看 | 久久久久成人精品 | 亚洲人人 | 精品人伦一区二区三区蜜桃网站 | 亚欧午夜| 久久国产精彩视频 | 天天看天天干 | 国产亚洲久 | 国产欧美日韩综合精品一区二区 | 99久久精品一区二区毛片吞精 | 一级在线观看 | 国产精品乱码一区二三区小蝌蚪 | 精品国产一区二区三区性色 | 国产精品成人一区二区三区夜夜夜 | 91在线观看免费视频 | 色婷婷综合久久久久中文一区二区 | 久久久久久国产精品mv | 九九色九九 | 亚洲一区二区三区免费视频 | 国产精品一区二区福利视频 | 国产1区2区 | 夜夜爽99久久国产综合精品女不卡 | 精品国产乱码久久久久久蜜退臀 |