成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ES6之Promise

andong777 / 2426人閱讀

摘要:什么是使用有什么優(yōu)勢是異步編程的一種解決方案,優(yōu)勢是可以避免層層嵌套的回調(diào)。代表一個異步操作,有三種狀態(tài)進行中已完成,又稱和已失敗。當(dāng)請求數(shù)據(jù)成功時,通過對外傳遞請求結(jié)果。

1.什么是promise?使用promise有什么優(yōu)勢?

promise是異步編程的一種解決方案,優(yōu)勢是可以避免層層嵌套的回調(diào)。

2.產(chǎn)生背景:
在promise出現(xiàn)之前,你肯定寫過這樣的代碼:

$.ajax({
    url1: "......",
    success: function (data1) {
        $.ajax({
            url2: "......",
            success: function (data2) {
               ... //data2的某些操作依賴于data1
            }
        });
    }
});

上述代碼中,如果還有data3依賴于data2,那么上述代碼將會存在更深層次的嵌套,promise的出現(xiàn)就是解決這些嵌套帶來的不優(yōu)雅和低可讀性等問題。

3.promise使用介紹

promise是一個對象,從這個對象中我們可以獲取異步操作的結(jié)果。
promise代表一個異步操作,有三種狀態(tài):
Pending(進行中)、Resolved(已完成,又稱 Fulfilled)和Rejected(已失?。?/p>

創(chuàng)建一個promise:

var promise = new Promise(function(resolve,reject){
    ...some code, such as http request
    if(success){
        resolve(data);   //異步請求成功時,通過resolve向外傳遞結(jié)果
    } else {
        reject(error);   //異步請求失敗時,通過reject向外傳遞結(jié)果
    }
});

簡單使用案例:

var MongoClient = require("mongodb").MongoClient;

var getData = function(url){
    var promise = new Promise(function(resolve,reject){
    MongoClient.connect(url, function(err, db){
        if(db){
             var collection = db.collection("users");
             collection.find({}).toArray(function(err,docs){
                resolve(docs);
             });
        }
        if(err){
            reject(err);
        }
    });
    });
    return promise;
}

getData("mongodb://localhost:27017/zuckjet").then(function(data){
    console.log(data);
},function(err){
    console.log(err);
});

上述代碼中,首先創(chuàng)建了一個函數(shù)getData,該函數(shù)返回一個promise實例。在該promise實例中,執(zhí)行的異步操作代碼是訪問本地mongodb數(shù)據(jù)庫數(shù)據(jù)。當(dāng)請求數(shù)據(jù)成功時,通過resolve對外傳遞請求結(jié)果。當(dāng)請求失敗時,通過reject對外傳遞錯誤信息。
promise.then()接受兩個回調(diào)函數(shù)作為參數(shù),第一個回調(diào)函數(shù)接收的是請求成功時的數(shù)據(jù),即上述代碼中resolve(docs)中的doc,第二個回調(diào)函數(shù)接收的是請求失敗時的信息,即上述代碼中reject(err)中的err。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82745.html

相關(guān)文章

  • ES6Promise

    摘要:什么是使用有什么優(yōu)勢是異步編程的一種解決方案,優(yōu)勢是可以避免層層嵌套的回調(diào)。代表一個異步操作,有三種狀態(tài)進行中已完成,又稱和已失敗。當(dāng)請求數(shù)據(jù)成功時,通過對外傳遞請求結(jié)果。 1.什么是promise?使用promise有什么優(yōu)勢? promise是異步編程的一種解決方案,優(yōu)勢是可以避免層層嵌套的回調(diào)。 2.產(chǎn)生背景:在promise出現(xiàn)之前,你肯定寫過這樣的代碼: $.ajax({ ...

    qc1iu 評論0 收藏0
  • ES6 異步編程二:Promise

    摘要:今天對于處理異步調(diào)用已經(jīng)有了很多成熟的方案,在我看來這些方案都無外乎在解決一個問題如何能看似順序地傳遞異步調(diào)用的結(jié)果,本文要說的就是原生提供的一個解決方案。在對進行敘述之前,依舊引用阮大的入門一書中的章節(jié)便于大家更嚴(yán)謹和全面的學(xué)習(xí)和參考。 異步回調(diào)的泥潭 異步回調(diào)是最直接的異步結(jié)果處理模式,將一個回調(diào)函數(shù)callback扔進異步處理函數(shù)中,當(dāng)異步處理獲得結(jié)果之后再調(diào)用這個回調(diào)函數(shù)就可以...

    Gilbertat 評論0 收藏0
  • ES6 系列 Babel 將 Async 編譯成了什么樣子

    摘要:大約后輸出我們直接在官網(wǎng)的粘貼上述代碼,然后查看代碼編譯成什么樣子相關(guān)的代碼我們在系列之將編譯成了什么樣子中已經(jīng)介紹過了,這次我們重點來看看函數(shù)以上這段代碼主要是用來實現(xiàn)的自動執(zhí)行以及返回。 前言 本文就是簡單介紹下 Async 語法編譯后的代碼。 Async const fetchData = (data) => new Promise((resolve) => setTimeout...

    wangym 評論0 收藏0
  • es6深入理解promise

    摘要:形式非必須,也非必須調(diào)用把用函數(shù)表示在調(diào)用的時候用函數(shù)代碼更加同步化三是什么異步操作的終極解決方案寫法四總結(jié)不管用還是用還是用,都保證你寫的的返回值是一個對象 一、promise入門 1. Promise對象是什么 回調(diào)函數(shù)的另一種原生實現(xiàn),比之前回調(diào)函數(shù)的寫法機構(gòu)清晰,功能強大, 2.以前回調(diào)這么寫 function a(fn){ let h = 1; setTime...

    luckyw 評論0 收藏0
  • JS筆記

    摘要:從最開始的到封裝后的都在試圖解決異步編程過程中的問題。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。異步編程入門的全稱是前端經(jīng)典面試題從輸入到頁面加載發(fā)生了什么這是一篇開發(fā)的科普類文章,涉及到優(yōu)化等多個方面。 TypeScript 入門教程 從 JavaScript 程序員的角度總結(jié)思考,循序漸進的理解 TypeScript。 網(wǎng)絡(luò)基礎(chǔ)知識之 HTTP 協(xié)議 詳細介紹 HTT...

    rottengeek 評論0 收藏0

發(fā)表評論

0條評論

andong777

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<