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

ES6新特性六:promise對象實例詳解

 更新時間:2017年04月21日 10:35:42   作者:Dason_yu  
這篇文章主要介紹了ES6新特性之promise對象,結合實例形式詳細分析了promise對象的功能、狀態(tài)、使用方法與相關操作技巧,需要的朋友可以參考下

本文實例講述了ES6新特性之promise對象。分享給大家供大家參考,具體如下:

1. promise 介紹

它是一個對象,也就是說與其他JavaScript對象的用法,沒有什么兩樣;其次,它起到代理作用(proxy),充當異步操作與回調函數(shù)之間的中介。它使得異步操作具備同步操作的接口,使得程序具備正常的同步運行的流程,回調函數(shù)不必再一層層嵌套。

它的思想是,每一個異步任務立刻返回一個Promise對象,由于是立刻返回,所以可以采用同步操作的流程。這個Promises對象有一個then方法,允許指定回調函數(shù),在異步任務完成后調用。

異步操作f1返回一個Promise對象,它的回調函數(shù)f2寫法如下

(new Promise(f1)).then(f2);

2. promise 對象的三種狀態(tài)

① 異步操作未完成(pending)
② 異步操作已完成(resolved)
③ 異步操作失?。╮ejected)

3. 工作過程

Promise對象使用then方法添加回調函數(shù)。then方法可以接受兩個回調函數(shù),第一個是異步操作成功時(變?yōu)閞esolved狀態(tài))時的回調函數(shù),第二個是異步操作失敗(變?yōu)閞ejected)時的回調函數(shù)(可以省略)。一旦狀態(tài)改變,就調用相應的回調函數(shù),這兩個回調函數(shù)都接受異步操作傳回的值作為參數(shù)。

promise.then(
 console.log,
 console.error
);

4. then 的鏈式使用

① 首先then方法返回的一個新的promise對象,因此可以采用鏈式寫法。

② then方法的第一個參數(shù)是Resolved狀態(tài)的回調函數(shù),第二個參數(shù)(可選)是Rejected狀態(tài)的回調函數(shù)。

③ 如下,promise的狀態(tài)一旦變?yōu)閞esolved,就依次調用后面每一個then指定的回調函數(shù),每一步都必須等到前一步完成,才會執(zhí)行。最后一個then方法的回調函數(shù)console.log和console.error,用法上有一點重要的區(qū)別。console.log只顯示回調函數(shù)step3的返回值,console.error可以顯示step1、step2、step3之中任意一個發(fā)生的錯誤,Promises對象的錯誤有傳遞性。

promise
 .then(step1)
 .then(step2)
 .then(step3)
 .then(
  console.log,
  console.error
 );

5. promise 對象的使用

var promise = new Promise(function(resolve, reject) { // promise的構造函數(shù),Promise構造函數(shù)接受一個函數(shù)作為參數(shù),該函數(shù)的兩個參數(shù)分別是resolve和reject
 // 異步操作的代碼
 if (/* 異步操作成功 */){
  resolve(value);//將異步的操作結果作為參數(shù)傳遞出去
 } else {
  reject(error);
 }
});

其中resolve和reject它們是兩個函數(shù),由JavaScript引擎提供,不用自己部署。

resolve函數(shù)的作用:將Promise對象的狀態(tài)從“未完成”變?yōu)椤俺晒Α保磸腜ending變?yōu)镽esolved),在異步操作成功時調用,并將異步操作的結果,作為參數(shù)傳遞出去;

reject函數(shù)的作用:將Promise對象的狀態(tài)從“未完成”變?yōu)椤笆 保磸腜ending變?yōu)镽ejected),在異步操作失敗時調用,并將異步操作報出的錯誤,作為參數(shù)傳遞出去。

① 下面是一個用Promise對象實現(xiàn)的Ajax操作的例子

var getJSON = function(url) {
 var promise = new Promise(function(resolve, reject){
  var client = new XMLHttpRequest();
  client.open("GET", url);
  client.onreadystatechange = handler;
  client.responseType = "json";
  client.setRequestHeader("Accept", "application/json");
  client.send();
  function handler() {
   if (this.readyState !== 4) {
    return;
   }
   if (this.status === 200) {
    resolve(this.response);//會將參數(shù)傳遞給回調函數(shù)
   } else {
    reject(new Error(this.statusText));
   }
  };
 });
 return promise;
};
getJSON("/posts.json").then(function(json) {
 console.log('Contents: ' + json);
}, function(error) {
 console.error('出錯了', error);
});

② resolve函數(shù)的參數(shù)除了正常的值以外,還可能是另一個Promise實例,即一個異步操作的結果是返回另一個異步操作。

var p1 = new Promise(function (resolve, reject) {
 // ...
});
var p2 = new Promise(function (resolve, reject) {
 // ...
 resolve(p1);
})

6.Promise.prototype.catch()

① 一個 Promise 對象,如果異步操作拋出錯誤,狀態(tài)就會變?yōu)镽ejected,就會調用catch方法指定的回調函數(shù),處理這個錯誤。

promise.then(function(posts) {
 // ...
}).catch(function(error) {
 // 處理 getJSON 和 前一個回調函數(shù)運行時發(fā)生的錯誤
 console.log('發(fā)生錯誤!', error);
});

② 另外,then方法指定的回調函數(shù),如果運行中拋出錯誤,也會被catch方法捕獲。

var promise = new Promise(function(resolve, reject) {
 throw new Error('test');
});
promise.catch(function(error) {
 console.log(error);
});
// Error: test

③ 另外兩種寫法

// 寫法一
var promise = new Promise(function(resolve, reject) {
 try {
  throw new Error('test');
 } catch(e) {
  reject(e);
 }
});
promise.catch(function(error) {
 console.log(error);
});
// 寫法二
var promise = new Promise(function(resolve, reject) {
 reject(new Error('test'));//reject方法的作用,等同于拋出錯誤
});
promise.catch(function(error) {
 console.log(error);
});

④ Promise 在resolve語句后面再拋出錯誤不會被捕獲。因為 Promise 的狀態(tài)一旦改變,就永久保持該狀態(tài),不會再變了。

var promise = new Promise(function(resolve, reject) {
 resolve('ok');
 throw new Error('test');
});
promise
 .then(function(value) { console.log(value) })
 .catch(function(error) { console.log(error) });
// ok

7 Promise.all()

參數(shù)為Promise 對象的數(shù)組;將多個Promisre 對象包裝成一個新的Promise 對象,如果數(shù)組中不是Promise 對象,就會自動調用 Promise.resolve方法,將參數(shù)轉為Promise實例,再進一步處理。(Promise.all方法的參數(shù)可以不是數(shù)組,但必須具有Iterator接口,且返回的每個成員都是Promise實例)

var p = Promise.all(promises).then(function (posts) {
 // ...
}).catch(function(reason){
 // ...
});

① 只要promises之中有一個狀態(tài)變?yōu)閞ejected,p的狀態(tài)就變成rejected,此時第一個被reject的實例的返回值,會傳遞給p的回調函數(shù)。
② 如果全部都變?yōu)閞esolved;此時 promises 數(shù)組中所有對象的返回值組成一個數(shù)組,傳遞給p的回調函數(shù)。

8 Promise.resolve()

將現(xiàn)有對象轉為 Promise對象,Promise.resolve方法就起到這個作用。

Promise.resolve('foo')
// 等價于
new Promise(resolve => resolve('foo'))

① 參數(shù)為Priomise 對象,Promise.resolve() 不做任何處理。
② 參數(shù)是一個具有 then 方法的對象:Promise.resolve方法會將這個對象轉為Promise對象,然后就立即執(zhí)行thenable對象的then方法。

let thenable = {
 then: function(resolve, reject) {
  resolve(42);
 }
};
let p1 = Promise.resolve(thenable);//p1為一個狀態(tài)已經(jīng)是resolved 的promise對象.
p1.then(function(value) {
 console.log(value); // 42
});

③ 參數(shù)不是具有then方法的對象,或根本就不是對象

該參數(shù)變?yōu)樯傻?Promise 對象的 resolve() 的參數(shù)。

var p = Promise.resolve('Hello');//Hello 會傳遞給 p 的resolve()
p.then(function (s){
 console.log(s)
});
// Hello

希望本文所述對大家ECMAScript程序設計有所幫助。

相關文章

  • ajax請求亂碼的解決方法(中文亂碼)

    ajax請求亂碼的解決方法(中文亂碼)

    這篇文章主要介紹了ajax請求亂碼的解決方法(中文亂碼),需要的朋友可以參考下
    2014-04-04
  • javascript 傳統(tǒng)事件模型構造的事件監(jiān)聽器實現(xiàn)代碼

    javascript 傳統(tǒng)事件模型構造的事件監(jiān)聽器實現(xiàn)代碼

    最近做東西需要添加大量的事件,而且要對所有事件進行比較細致的控制,于是便試著寫了個事件監(jiān)聽器。
    2010-05-05
  • JS實現(xiàn)頁面跳轉參數(shù)不丟失的方法

    JS實現(xiàn)頁面跳轉參數(shù)不丟失的方法

    這篇文章主要介紹了JS實現(xiàn)頁面跳轉參數(shù)不丟失的方法,結合實例形式對比分析了javascript URL加密函數(shù)escape()、encodeURI()與encodeURIComponent()的功能與相關使用技巧,需要的朋友可以參考下
    2016-11-11
  • 淺析JS中的原型,原型鏈和繼承

    淺析JS中的原型,原型鏈和繼承

    經(jīng)典模式和圣杯模式都是用于解決構造函數(shù)繼承和原型繼承的問題,但它們在實現(xiàn)繼承的方式上有所不同,本文主要來和大家聊聊經(jīng)典模式和圣杯模式下原型,原型鏈和繼承的實現(xiàn),需要的可以參考下
    2023-09-09
  • canvas簡單快速的實現(xiàn)知乎登錄頁背景效果

    canvas簡單快速的實現(xiàn)知乎登錄頁背景效果

    本篇文章主要介紹了canvas簡單快速實現(xiàn)知乎登錄頁背景效果的相關知識,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-05-05
  • canvas實現(xiàn)愛心和彩虹雨效果

    canvas實現(xiàn)愛心和彩虹雨效果

    本文主要介紹了canvas實現(xiàn)愛心和彩虹雨效果的實例,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • js的flv視頻播放器插件使用方法

    js的flv視頻播放器插件使用方法

    FLV格式的視頻很流行,有些網(wǎng)站程序不支持這個功能,我找到了一個強大FLV視頻播放器插件,可以自定義播放器界面顏色,可設置播放器默認圖片等等,推薦給大家。
    2015-06-06
  • 基于JavaScript實現(xiàn)簡單的輪播圖

    基于JavaScript實現(xiàn)簡單的輪播圖

    這篇文章主要為大家詳細介紹了基于JavaScript實現(xiàn)簡單的輪播圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • js檢測輸入內容全為空格的方法

    js檢測輸入內容全為空格的方法

    這篇文章主要介紹了js檢測輸入內容全為空格的方法,,需要的朋友可以參考下
    2014-05-05
  • JavaScript?數(shù)組基本操作全解

    JavaScript?數(shù)組基本操作全解

    今天這篇文章就是來和大家詳細聊聊JavaScript中數(shù)組的基本操作,很多語言都是在數(shù)組這有個分水嶺。聽懂了接下來就很容易,聽不懂就難辦了,大家要認真看喲。希望大家讀完有所收獲,那我辛苦碼字也就值了
    2022-02-02

最新評論