• <ins id="rwosr"><acronym id="rwosr"></acronym></ins>
      <kbd id="rwosr"></kbd>

      1. <tr id="rwosr"></tr>
        <code id="rwosr"></code> <output id="rwosr"><track id="rwosr"></track></output>

        <output id="rwosr"><track id="rwosr"></track></output>
        <sup id="rwosr"><track id="rwosr"></track></sup>
        <tr id="rwosr"><nobr id="rwosr"><delect id="rwosr"></delect></nobr></tr>

        <output id="rwosr"><track id="rwosr"></track></output>
        400-650-7353
        您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】如何利用promise解決異步

        【Web前端基礎知識】如何利用promise解決異步

        • 發布: Web前端培訓
        • 來源:優就業
        • 2021-09-28 14:16:38
        • 閱讀()
        • 分享
        • 手機端入口

        我們知道,在promise對象的then方法可以處理onfulfilled和onrejected兩個事件監聽回調,但是我們一般采用catch來處理onrejected的監聽回調,因為catch可以捕獲部分程序異常;有利于程序的健壯性。例如:

        1. function getBanner() { 
        2.            let p = new Promise((resolve, reject) => { 
        3.                $.ajax({ 
        4.                    type: "GET"
        5.                    url: "http://localhost:3000/api/index/banner"
        6.                    success: function (response) { 
        7.                        resolve(response); 
        8.                    }, 
        9.                    error: function (err) { 
        10.                        reject(err); 
        11.                    } 
        12.                }); 
        13.            }); 
        14.            return p; 
        15.        } 
        16.  
        17.        let p = getBanner() 
        18.            .then(rst => { 
        19.                return rst; 
        20.            }) 
        21.            .catch(err => { 
        22.                console.log(err); 
        23.            }); 

        我們通過jQuery的ajax來向服務器發起輪播圖數據的請求,上面代碼若是正確的執行則會進入then方法里處理,若是異常的,也就是說必然進入catch環節,這代碼看起來并沒有什么,好像也并不復雜。

        但是,如果在異步請求過程中出現了幾個請求直接有依賴關系,則使用這種解決方案就復雜得多了。例如:

        1. $.ajax({ 
        2.            url: "http://www.ujiuye.tech/:3000/api/firstCategory", // 所有一級分類 
        3.            dataType: "json"
        4.            success(res) { 
        5.                $.ajax({ 
        6.                    url: `http://www.ujiuye.tech/:3000/api/secondCategory`, // 傳遞一級ID換取下屬的二級分類列表 
        7.                    data: { 
        8.                        firstId: res['list'][0][0]['firstId'
        9.                    }, 
        10.                    dataType: "json"
        11.                    success(res2) { 
        12.                        $.ajax({ 
        13.                            url: `http://www.ujiuye.tech/:3000/api/thiredCategory`, // 傳遞二級分類ID, 獲取下屬的三級分類列表 
        14.                            data: { 
        15.                                secondId: res2['list'][0]['secondId'
        16.                            }, 
        17.                            dataType: "json"
        18.                            success(res3) { 
        19.                                $.ajax({ 
        20.                                    url: `http://www.ujiuye.tech/:3000/api/categoryList`,// 傳遞三級分類ID, 獲取下屬的商品數據列表 
        21.                                    data: { 
        22.                                        thiredId: res3['list'][0]['thiredId'
        23.                                    }, 
        24.                                    dataType: "json"
        25.                                    success(result) { 
        26.                                        console.log(result); 
        27.                                    } 
        28.                                }) 
        29.                            } 
        30.                        }) 
        31.                    } 
        32.                }) 
        33.            } 
        34.        }) 

        在小U商城項目中的商品列表頁面,我們同時要發起四個請求來分別獲。阂患壏诸、二級分類、三級分類和商品,那么這是時候利用回調函數會出現”回調地獄”的現象,即使是使用promise來優化,也會出現大量的代碼嵌套,這樣的代碼會容易讓人疑惑,而且也不利于后續的開發維護。所以我們可以使用async...await來優化這些。

        例如上面請求輪播圖的例子,使用async和await來優化之后:

        1. function getBanner() { 
        2.             let p = new Promise((resolve, reject) => { 
        3.                 $.ajax({ 
        4.                     type: "GET"
        5.                     url: "http://localhost:3000/api/index/banner"
        6.                     success: function (response) { 
        7.                         resolve(response); 
        8.                     }, 
        9.                     error: function (err) { 
        10.                         reject(err); 
        11.                     } 
        12.                 }); 
        13.             }); 
        14.             return p; 
        15.         } 
        16.  
        17.         async function getData(){ 
        18.             let data=await getBanner(); 
        19.             console.log(data); 
        20.         } 

        這樣的代碼相比于上面的代碼要簡化很多,但是也有弊端,由于await只能接收promise的成功結果,也就是說,若上面代碼出現了異常,則代碼會中斷執行。作為一個優秀的開發人員肯定不希望代碼崩掉,那么該如何解決異常呢,有兩種方案:一是采用try..catch來捕獲異常,另外是使用catch

        1. async function getData() { 
        2.             try { 
        3.                 let data = await getBanner(); 
        4.                 console.log(data); 
        5.             } catch (e) { 
        6.                 console.log(e); 
        7.             } 
        8.         } 
        9.  
        10.         //或者 
        11.         async function getData() { 
        12.             let data = await getBanner().catch(e => { 
        13.                 console.log(e); 
        14.             }) 
        15.             console.log(data); 
        16.         } 

        但這兩種方案都又會出現嵌套,特別是若發起一些負責的請求(例如上面回調地獄的情況),則代碼依然非常復雜,那么有沒有更好的解決方案呢。答案是有。在項目開發過程中,我們經常使用await-to-js的技術來解決這個問題:

        1. function to(p) { 
        2.            return p 
        3.                .then(data => [null, data]) 
        4.                .catch(err => [err, null]); 
        5.        } 

        其實這個方案依然是利用promise的鏈式調用原理來解決的。那么使用,最后代碼為:

        1. function to(p) { 
        2.            return p 
        3.                .then(data => [null, data]) 
        4.                .catch(err => [err, null]); 
        5.        } 
        6.  
        7.        async function getData() { 
        8.            let [err, data] = await to(getBanner()) 
        9.        } 

        利用這個方案,大家發現,代碼量不僅大大的減少,而且兼容性更加友好。

        文章“【Web前端基礎知識】如何利用promise解決異步”已幫助

        更多內容

        >>本文地址:http://www.littlerockbway.com/zhuanye/2021/70198.html

        THE END  

        聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

        1 您的年齡

        2 您的學歷

        3 您更想做哪個方向的工作?

        獲取測試結果
        • 大前端大前端
        • 大數據大數據
        • 互聯網營銷互聯網營銷
        • JavaJava
        • Linux云計算Linux
        • Python+人工智能Python
        • 嵌入式物聯網嵌入式
        • 全域電商運營全域電商運營
        • 軟件測試軟件測試
        • 室內設計室內設計
        • 平面設計平面設計
        • 電商設計電商設計
        • 網頁設計網頁設計
        • 全鏈路UI/UE設計UI設計
        • VR/AR游戲開發VR/AR
        • 網絡安全網絡安全
        • 新媒體與短視頻運營新媒體
        • 直播帶貨直播帶貨
        • 智能機器人軟件開發智能機器人
         

        快速通道fast track

        近期開班時間TIME

        两个人在线观看免费播放_国产精品天干天干_亚洲婷婷月色婷婷五月小蛇_男人的好小说全文免费阅读
      2. <ins id="rwosr"><acronym id="rwosr"></acronym></ins>
          <kbd id="rwosr"></kbd>

          1. <tr id="rwosr"></tr>
            <code id="rwosr"></code> <output id="rwosr"><track id="rwosr"></track></output>

            <output id="rwosr"><track id="rwosr"></track></output>
            <sup id="rwosr"><track id="rwosr"></track></sup>
            <tr id="rwosr"><nobr id="rwosr"><delect id="rwosr"></delect></nobr></tr>

            <output id="rwosr"><track id="rwosr"></track></output>
            <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <文本链> <文本链> <文本链> <文本链> <文本链> <文本链>