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

JavaScript異步編程Promise模式的6個特性

 更新時間:2014年04月03日 09:21:26   作者:  
Promise說起來是一個非常簡單的概念,即使你沒有機會去使用它,很有可能你也了解過它。Promise是一個非常有價值的構(gòu)造器,能夠幫助你避免使用鑲套匿名方法,而使用更具有可讀性的方式組裝異步代碼。這里我們將介紹6個最簡單的特性,希望對大家有幫助

在我們開始正式介紹之前,我們想看看Javascript Promise的樣子:

復(fù)制代碼 代碼如下:

var p = new Promise(function(resolve, reject) {
  resolve("hello world");
});

p.then(function(str) {
  alert(str);
});

1. then()返回一個Forked Promise

以下兩段代碼有什么區(qū)別呢?

復(fù)制代碼 代碼如下:

// Exhibit A
var p = new Promise(/*...*/);
p.then(func1);
p.then(func2);

// Exhibit B
var p = new Promise(/*...*/);
p.then(func1)
.then(func2);

如果你認(rèn)真以上兩段代碼等同的話,那么Promises只不過是一個一維的回調(diào)函數(shù)數(shù)組。然而,其實不是這樣的。每一個then()調(diào)用都返回一個forked promise。因此,ExhibitA中,如果func1()拋出一個異常,func2()仍舊正常調(diào)用。

在ExhibitB中,如果func1()拋出一個錯誤,fun2()將不會被調(diào)用,因為第一個調(diào)用返回了一個新的promise,這個在func1()中會被拒絕。結(jié)果是func2()被跳過。

總結(jié):promises可以被fork成多個路徑,類似復(fù)雜的流程圖。

2. Callback應(yīng)該傳遞結(jié)果

當(dāng)你運行下面代碼的時候什么會得到警告提示呢?

復(fù)制代碼 代碼如下:

var p = new Promise(function(resolve, reject) {
  resolve("hello world");
});

p.then(function(str) {})
.then(function(str) {
  alert(str);
});

第二個then()中的alert沒有顯示任何內(nèi)容。這是因為回調(diào)函數(shù),在promise的上下文中,因為結(jié)果的變化并沒有回調(diào)函數(shù)。promise期望你的回調(diào)函數(shù)返回同樣的結(jié)果或者返回一個替換結(jié)果,然后被傳遞到下一個回調(diào)函數(shù)中。

類似使用adpater來變化結(jié)果,如下:

復(fù)制代碼 代碼如下:

var feetToMetres = function(ft) { return ft*12*0.0254 };

var p = new Promise(/*...*/);

p.then(feetToMetres)
.then(function(metres) {
  alert(metres);
});

3. 只有來自上一層的異常可以被捕捉

這兩段代碼有什么區(qū)別?

復(fù)制代碼 代碼如下:

// Exhibit A
new Promise(function(resolve, reject) {
  resolve("hello world");
})
.then(
  function(str) {
    throw new Error("uh oh");
  },
  undefined
)
.then(
  undefined,
  function(error) {
    alert(error);
  }
);
 

// Exhibit B
new Promise(function(resolve, reject) {
  resolve("hello world");
})
.then(
  function(str) {
    throw new Error("uh oh");
  },
  function(error) {
    alert(error);
  }
);


在第一段代碼中,在第一個then()中的異常被拋出,將會被第二個then()捕捉,然后“uh oh”警告將會被觸發(fā)。這個遵循只有前一個層次的異常會被捕捉。

在第二段代碼中,回調(diào)函數(shù)和錯誤回調(diào)函數(shù)是同一個層次,意味著當(dāng)異常在回調(diào)中拋出,將不會被捕捉。事實上,第二段代碼的錯誤回調(diào)將只會在promise為拒絕狀態(tài)或者promise本身出錯的情況下拋出

4. 錯誤可以被恢復(fù)

在一個錯誤回調(diào)函數(shù)中,如果你不重新拋出錯誤,promise會假設(shè)你已經(jīng)從錯誤中恢復(fù),并且反轉(zhuǎn)成為已解決狀態(tài)。在下一個例子中,"i'm saved" 將會被顯示,這是因為在第一個then()中的錯誤回調(diào)沒有重新拋出異常。

復(fù)制代碼 代碼如下:

var p = new Promise(function(resolve, reject) {
  reject(new Error("pebkac"));
});

p.then(
  undefined,
  function(error) { }
)
.then(
  function(str) {
    alert("I am saved!");
  },
  function(error) {
    alert("Bad computer!");
  }
);

Promise可以被看作洋蔥上的層次。每一個then()添加另外一個層次到洋蔥上。每一個層次代表了一個被處理的活動。當(dāng)層次結(jié)束,結(jié)果被認(rèn)為已經(jīng)修復(fù)并且為下一個層次做好了準(zhǔn)備。

5. Promises可以被暫停

因為你已經(jīng)準(zhǔn)備好了在一個then()方法中執(zhí)行,并不意味著你不能夠暫停并且提前運行其他。 為了暫停目前的promise,或者讓它等待以便另外一個promise完成,簡單在then()中返回另外一個promise。

復(fù)制代碼 代碼如下:

var p = new Promise(/*...*/);

p.then(function(str) {
  if(!loggedIn) {
    return new Promise(/*...*/);
  }
})
.then(function(str) {
  alert("Done.");
})

在前面代碼中,直到新的promise解析后提示才會出現(xiàn)。這是一個方便的方式在已存在的異步代碼路徑中來引入更多地依賴。例如,你可能發(fā)現(xiàn)用戶session已經(jīng)timeout,并且你可能希望在繼續(xù)前面的代碼路徑前初始化第二個登陸。

6. Resolved Promises并不會立刻執(zhí)行

運行下面代碼會得到提示框么?

復(fù)制代碼 代碼如下:

function runme() {
  var i = 0;

  new Promise(function(resolve) {
    resolve();
  })
  .then(function() {
    i += 2;
  });
  alert(i);
}

因為promise被立刻解析,然后then()方法被立刻執(zhí)行,所以你可能會認(rèn)為會探出提示2。但是promise定義要求所有的調(diào)用都被強制異步。因此提示會在被修改前生成。

相關(guān)文章

  • 關(guān)于js注冊事件的常用方法

    關(guān)于js注冊事件的常用方法

    為了兼容各種瀏覽器,今天沒事特意復(fù)習(xí)了一下js原生事件特性,對其封裝一下。
    2013-04-04
  • 沒有document.getElementByName方法

    沒有document.getElementByName方法

    document.getElementByName方法沒有document.getElementsByName得到的是標(biāo)簽的數(shù)組,下面為大家詳細(xì)介紹下具體的使用,感興趣的朋友可以參考下,希望對大家有所幫助
    2013-08-08
  • 超實用的JavaScript表單代碼段

    超實用的JavaScript表單代碼段

    這篇文章主要為大家分享了超實用的JavaScript表單代碼段,幫助大家更好地學(xué)習(xí)使用javascript表單操作,感興趣的小伙伴們可以參考一下
    2016-02-02
  • js數(shù)值計算時使用parseInt進行數(shù)據(jù)類型轉(zhuǎn)換(jquery)

    js數(shù)值計算時使用parseInt進行數(shù)據(jù)類型轉(zhuǎn)換(jquery)

    這篇文章主要介紹了js數(shù)值計算時使用parseInt進行數(shù)據(jù)類型轉(zhuǎn)換(jquery),需要的朋友可以參考下
    2014-10-10
  • JavaScript中這6個新特性你都了解了嗎

    JavaScript中這6個新特性你都了解了嗎

    作為一門不斷演進的語言,JavaScript每年都會引入新特性,這篇文章主要為大家整理了一些個人認(rèn)為特別有用的新JavaScript特性,以及一些補充的實例代碼,希望對大家有所幫助
    2024-01-01
  • javascript基本包裝類型介紹

    javascript基本包裝類型介紹

    這篇文章主要介紹了javascript的基本包裝類型,JS為了便于操作基本類型,提供了3個特殊的引用類型:Boolean/Number和String,需要的朋友可以參考下
    2015-04-04
  • JS如何實現(xiàn)文本框隨文本的長度而增長

    JS如何實現(xiàn)文本框隨文本的長度而增長

    這篇文章主要介紹了JS如何實現(xiàn)文本框隨文本的長度而增長的方法,具有一定借鑒價值,需要的朋友可以參考下
    2015-07-07
  • JavaScript數(shù)組合并案例講解

    JavaScript數(shù)組合并案例講解

    這篇文章主要介紹了JavaScript數(shù)組合并案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • js運算精度丟失的2個解決方法

    js運算精度丟失的2個解決方法

    近期在做項目的時候,遇到了一些JS浮點數(shù)精度的問題,這個問題其實說大不大,說小不小,下面這篇文章主要給大家介紹了關(guān)于js運算精度丟失的2個解決方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • Bootstrap基本組件學(xué)習(xí)筆記之導(dǎo)航(10)

    Bootstrap基本組件學(xué)習(xí)筆記之導(dǎo)航(10)

    這篇文章主要為大家詳細(xì)介紹了Bootstrap基本組件學(xué)習(xí)筆記之導(dǎo)航,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評論