• <b id="gimrh"><noscript id="gimrh"></noscript></b>
    1. <video id="gimrh"><menu id="gimrh"></menu></video>
      <tt id="gimrh"><tbody id="gimrh"></tbody></tt>

      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.threeriversmusicproducts.com/zhuanye/2021/70198.html

      THE END  

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

      領取零基礎自學IT資源

      (內含學習路線+視頻教程+項目源碼)

      涉及Java、Web前端、UI設計、軟件測試、Python等多個IT熱門方向

      打開微信掃一掃即可領取哦~

      1 您的年齡

      2 您的學歷

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

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

      快速通道fast track

      近期開班時間TIME

      bl乱J伦高HH

    2. <b id="gimrh"><noscript id="gimrh"></noscript></b>
      1. <video id="gimrh"><menu id="gimrh"></menu></video>
        <tt id="gimrh"><tbody id="gimrh"></tbody></tt>