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

自定義事件解決重復請求BUG的問題

 更新時間:2017年07月11日 08:10:28   投稿:jingxian  
下面小編就為大家?guī)硪黄远x事件解決重復請求BUG的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

現(xiàn)在,組件化開發(fā)還是比較流行的,畢竟其優(yōu)點相當突出。最近在開發(fā)一個組件的時候,遇到了一個很有意思的BUG。。。

BUG的背景

最近在開發(fā)一個組件,好不容易開發(fā)好了轉測試。然后,測試給我提了一個這樣的bug,orz...

因為是一個組件,最大的好處就是可以隨處復用,隨處使用,然而,當一個頁面用了多個組件,只有最后一個生效的時候,這個組件就沒有什么意義了。。。

BUG原因查找

這個組件的初始數(shù)據(jù)來源的接口是固定的,也就是說,頁面內(nèi)的所有這個組件在初始化的時候都會發(fā)出同樣的請求,這里的請求是jsonp的方式,所以回調函數(shù)是綁定在window上的一個函數(shù),但是在頁面中window只有一個,所以在回調處理的時候,要處理的組件內(nèi)的相應的數(shù)據(jù)只指向最后一個組件。所以導致多個同樣的組件在同一個頁面中,只有最后一個組件能在取得數(shù)據(jù)之后順利渲染出來。

BUG解決思路

最主要就是要將每次請求的callback存儲起來,這樣就可以保證callback中對組件數(shù)據(jù)的處理不是只指向最后一個。其次,既然是一樣的請求,當然不希望會發(fā)出兩次以上啦,即一個頁面發(fā)出的每一個請求都是唯一的。

BUG解決方案

想到了發(fā)布訂閱者模式的自定義事件,可以寫這樣的一個模塊,每次請求發(fā)出前判斷一下之前是否有相同的模塊已經(jīng)發(fā)出了,如果沒有則緩存callback發(fā)出請求,如果有相同的請求已經(jīng)發(fā)出了,那么檢查一下這個發(fā)出的請求是否已經(jīng)完成了,如果沒有則繼續(xù)緩存callback等待,如果請求已經(jīng)發(fā)出并且已經(jīng)完成則直接處理callback。在請求第一次回來后,發(fā)出廣播,把之前緩存的callback都執(zhí)行一次。

自定義事件詳情

定義一個模塊,里面有n個以回調函數(shù)命名的事件對象,每個對象有在被初始化的時候,定義其狀態(tài)state,對應的callback數(shù)組,請求回到的數(shù)據(jù)data。每次調用該模塊,首先檢查對應的cbName是否被初始化,然后檢查其state。根據(jù)state做相應的操作并改變state的值。state的值有3中,分別為init、loading、loaded。即初始化、請求中、請求完成。處于請求完成狀態(tài)時才能執(zhí)行相應的回調。

具體如下:

define('wq.getData', function (require, exports, module) {
  var ls = require('loadJs');
   
  var cache = {};
  cache.init = function(cb,cbName,url){
    if(!cache[cbName]){
      cache[cbName] = {};
      cache[cbName].state = 'init';
      cache[cbName].cbs = [];
      cache[cbName].data = [];
    }
    cache.on(cb,cbName,url);
  }
  cache.on = function(cb,cbName,url){
    if(cache[cbName].state == 'loaded'){
      cb(cache[cbName].data)
    }else if(cache[cbName].state == 'loading'){
      cache[cbName].cbs.push(cb)
    }else if(cache[cbName].state == 'init'){
      cache[cbName].cbs.push(cb);
      cache[cbName].state = 'loading';
      cache.fetch(cb,cbName,url);
    }
  }
  cache.broadcast = function(cbName){
    cache[cbName].cbs.forEach(function(cb){
      cb(cache[cbName].data)
    });
  }
  cache.checkLoaded = function(cbName){
    if(cache[cbName].data[0]){
      cache[cbName].state = 'loaded';
      cache.broadcast(cbName);
    }
  }
  cache.fetch = function(cb,cbName,url){
    ls.loadScript({
      url: url,
      charset: 'utf-8',
      handleError:function(func, args, context,errorObj){
        console.log(_errlogText + context);
        cache[cbName].data[0] = {};
        cache.checkLoaded(cbName);
      }
    });
    if(window.cbName) return;
    window[cbName] = function(json){
      cache[cbName].data[0] = json;
      cache.checkLoaded(cbName);
    }
  }
 
  exports.getData = function(cb,cbName,url){
    cache.init(cb,cbName,url);
  } 
 
})

完美解決問題,每個回調都不會遺漏或者被覆蓋……

擴展思路

該模塊可通用于處理一個頁面內(nèi)同一個請求的情況。還可以擴展到處理一些需要2個請求以上完成才執(zhí)行某個回調的情況。類似于Promose的情況。這個時候可以規(guī)定,每個data[0]裝的是固定的對應接口的數(shù)據(jù),data[2]對應另一個,一次類推。不過這樣就要遍歷到每一項都為true的時候才執(zhí)行回調。而且對應關系比較容易混亂,再擴展就不如直接用Promise來處理了。。。

以上這篇自定義事件解決重復請求BUG的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • JS+CSS實現(xiàn)可拖拽的漂亮圓角特效彈出層完整實例

    JS+CSS實現(xiàn)可拖拽的漂亮圓角特效彈出層完整實例

    這篇文章主要介紹了JS+CSS實現(xiàn)可拖拽的漂亮圓角特效彈出層,以完整實例形式分析了彈出層特效及圓角矩形的實現(xiàn)技巧,需要的朋友可以參考下
    2015-02-02
  • Javascript 構造函數(shù) 實例分析

    Javascript 構造函數(shù) 實例分析

    一般構造函數(shù)沒有返回值,他們通過關鍵字this初始化對象,沒有返回值。當然一個構造器允許返回一個對 象,如果這樣的話 返回的對象將變成new 表達式的值,在這種情況下值為this的對象將拋棄
    2008-11-11
  • JavaScript的11個小技巧整理

    JavaScript的11個小技巧整理

    這篇文章介紹了JavaScript的11個小技巧,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法

    LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法

    今天小編就為大家分享一篇LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS實現(xiàn)多物體運動

    JS實現(xiàn)多物體運動

    這篇文章主要為大家詳細介紹了JS實現(xiàn)多物體運動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • JS實現(xiàn)自定義簡單網(wǎng)頁軟鍵盤效果代碼

    JS實現(xiàn)自定義簡單網(wǎng)頁軟鍵盤效果代碼

    這篇文章主要介紹了JS實現(xiàn)自定義簡單網(wǎng)頁軟鍵盤效果代碼,可實現(xiàn)簡單模擬鍵盤布局及響應鼠標點擊按下鍵盤按鍵功能,簡單實用,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • JavaScript中的console.time()函數(shù)詳細介紹

    JavaScript中的console.time()函數(shù)詳細介紹

    這篇文章主要介紹了JavaScript中的console.time()函數(shù)詳細介紹,console.time()函數(shù)主要用來統(tǒng)計程序執(zhí)行時間,需要的朋友可以參考下
    2014-12-12
  • Bootstrap table使用方法詳細介紹

    Bootstrap table使用方法詳細介紹

    bootstrap-table是在bootstrap-table的基礎上寫出來的,專門用于顯示數(shù)據(jù)的表格插件。這篇文章主要為大家詳細介紹了JS組件Bootstrap Table使用方法,具有一定的實用性和參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • jstree創(chuàng)建無限分級樹的方法【基于ajax動態(tài)創(chuàng)建子節(jié)點】

    jstree創(chuàng)建無限分級樹的方法【基于ajax動態(tài)創(chuàng)建子節(jié)點】

    這篇文章主要介紹了jstree創(chuàng)建無限分級樹的方法,結合實例形式分析了jstree基于ajax結合asp.net后臺動態(tài)創(chuàng)建子節(jié)點實現(xiàn)無限分級樹效果的相關步驟與操作技巧,需要的朋友可以參考下
    2016-10-10
  • Android 自定義view仿微信相機單擊拍照長按錄視頻按鈕

    Android 自定義view仿微信相機單擊拍照長按錄視頻按鈕

    這篇文章主要介紹了Android 自定義view仿微信相機單擊拍照長按錄視頻按鈕,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-07-07

最新評論