<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        JavaScript異步回調的Promise模式封裝實例_javascript技巧

        來源:懂視網 責編:小采 時間:2020-11-27 21:24:05
        文檔

        JavaScript異步回調的Promise模式封裝實例_javascript技巧

        JavaScript異步回調的Promise模式封裝實例_javascript技巧:網頁的交互越來越復雜,JavaScript 的異步操作也隨之越來越多。如常見的 ajax 請求,需要在請求完成時響應操作,請求通常是異步的,請求的過程中用戶還能進行其他的操作,不會對頁面進行阻塞,這種異步的交互效果對用戶來說是挺有友好的。但是對于開發者來說
        推薦度:
        導讀JavaScript異步回調的Promise模式封裝實例_javascript技巧:網頁的交互越來越復雜,JavaScript 的異步操作也隨之越來越多。如常見的 ajax 請求,需要在請求完成時響應操作,請求通常是異步的,請求的過程中用戶還能進行其他的操作,不會對頁面進行阻塞,這種異步的交互效果對用戶來說是挺有友好的。但是對于開發者來說

        網頁的交互越來越復雜,JavaScript 的異步操作也隨之越來越多。如常見的 ajax 請求,需要在請求完成時響應操作,請求通常是異步的,請求的過程中用戶還能進行其他的操作,不會對頁面進行阻塞,這種異步的交互效果對用戶來說是挺有友好的。但是對于開發者來說,要大量處理這種操作,就很不友好了。異步請求完成的操作必須預先定義在回調函數中,等到請求完成就必須調用這個函數。這種非線性的異步編程方式會讓開發者很不適應,同時也帶來了諸多的不便,增加了代碼的耦合度和復雜性,代碼的組織上也會很不優雅,大大降低了代碼的可維護性。情況再復雜點,如果一個操作要等到多個異步 ajax 請求的完成才能進行,就會出現回調函數嵌套的情況,如果需要嵌套好幾層,那你就只能自求多福了。
        先看看下面這個常見的異步函數。

        代碼如下:
        var showMsg = function(){
        setTimeout(function(){
        alert( 'hello' );
        }, 5000 );
        };

        如果要給該函數添加回調,通常會這么干。
        代碼如下:
        var showMsg = function( callback ){
        setTimeout(function(){
        alert( 'hello' );
        // 此處添加回調
        callback();
        }, 5000 );
        };

        如果是使用 easy.js 的 Promise,添加回調的方法就會優雅多了,前提是需要將原函數封裝成一個 promise 實例。
        代碼如下:
        var showMsg = function(){
        // 構造promise實例
        var promise = new E.Promise();

        setTimeout(function(){
        alert( 'hello' );

        // 改變promise的狀態
        promise.resolve( 'done' );
        }, 5000 );

        // 返回promise實例
        return promise;
        };

        將一個普通的函數封裝成一個 promise 實例,有3個關鍵步驟,第一步是在函數內部構造一個 promise 實例,第二步是部署函數執行完去改變 promise 的狀態為已完成,第三步就是返回這個 promise 實例。每個 promise 實例都有3種狀態,分別為 pending(未完成)、resolved(已完成,成功)、rejected(已拒絕,失敗)。下面再來看看如何添加回調。

        代碼如下:
        showMsg().then(function( str ){
        // 回調添加到這里來了
        callback( str );
        });

        這樣就將回調函數和原來的異步函數徹底的分離了,從代碼組織上看,優雅了很多。resolve 接受一個參數,該參數就可以輕松實現將數據傳送給使用 then 方法添加的回調中。
        對于 ajax 請求,easy.js 直接將 ajax 方法封裝成了 promise 對象,可以直接添加 then 方法來回調。
        代碼如下:
        E.ajax({
        url : 'test1.php',
        type : 'GET'
        })
        .then(function(){
        // 添加請求成功的回調
        }, function(){
        // 添加請求失敗的回調
        });

        then 方法接受2個函數作為參數,第一個函數是已完成的回調,第二個就是已失敗的回調。
        如果有上面提到的多個 ajax 請求的情況呢?那么就要用到 when 這個方法了。該方法可以接受多個 promise 實例作為參數。

        代碼如下:
        var requests = E.when(E.ajax({
        url : 'test1.php',
        type : 'GET'
        }), E.ajax({
        url : 'test2.php',
        type : 'GET'
        }));

        requests.then(function( arg1, arg2 ){
        console.log( 'success:' + arg1[0] + arg2[0] );
        }, function( arg1, arg2 ){
        console.log( 'failure:' + arg1 + arg2 );
        });

        when 方法是將多個 promise 實例存到一個數組中,等到該數組的所有 promise 實例都是已完成狀態才去執行已完成的回調,一旦有一個實例是已拒絕的狀態,則立即執行已拒絕的回調。

        Promise 模式是 CommonJS 的規范之一。很多主流的 JavaScript 庫都有相應的實現,如 jQuery 和 Dojo 中,都有 Deferred 去實現這些功能。在這里還是要吐槽下 jQuery 的 Deferred,撇開其內部使用,這應該用戶使用率最低的一個模塊了,這和其較復雜的使用方式有一定的關系。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        JavaScript異步回調的Promise模式封裝實例_javascript技巧

        JavaScript異步回調的Promise模式封裝實例_javascript技巧:網頁的交互越來越復雜,JavaScript 的異步操作也隨之越來越多。如常見的 ajax 請求,需要在請求完成時響應操作,請求通常是異步的,請求的過程中用戶還能進行其他的操作,不會對頁面進行阻塞,這種異步的交互效果對用戶來說是挺有友好的。但是對于開發者來說
        推薦度:
        標簽: js 封裝 java
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top 主站蜘蛛池模板: 无人影院手机版在线观看免费| 国产精品黄页免费高清在线观看| 全免费a级毛片免费看| 国产精品亚洲二区在线观看| 九九全国免费视频| 久久久久亚洲精品无码网址 | 亚洲国产一级在线观看| 国产91成人精品亚洲精品| 国产麻豆剧传媒精品国产免费| 亚洲avav天堂av在线网毛片| 永久黄网站色视频免费观看| 国产产在线精品亚洲AAVV| 亚洲成年人啊啊aa在线观看| 一个人晚上在线观看的免费视频| 亚洲午夜爱爱香蕉片| a级片免费观看视频| 亚洲图片在线观看| 免费人成在线视频| 国产成人精品亚洲一区| 亚洲午夜国产精品无码老牛影视| 精品国产污污免费网站| 亚洲精品在线免费观看视频| 日韩免费a级毛片无码a∨| 精品国产日韩亚洲一区91| 自拍偷自拍亚洲精品情侣| 午夜老司机永久免费看片| 99热亚洲色精品国产88| 国产午夜影视大全免费观看| 国产一二三四区乱码免费| 亚洲国产精品人久久电影| 国产精品国产免费无码专区不卡 | 成年大片免费视频| 黄色网页免费观看| 亚洲AV无码成人精品区在线观看 | 亚洲中文字幕一二三四区| 亚洲成a人片在线观看国产| 国产成人无码区免费内射一片色欲| 精品日韩亚洲AV无码 | 亚洲精品午夜无码专区| 毛片免费全部播放一级| 四虎一区二区成人免费影院网址|