日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢(xún)客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747


現(xiàn)在因?yàn)橛袀€(gè)上傳組件他用到了這個(gè)mixin文件,這個(gè)mixin文件中mounted請(qǐng)求了接口,這樣一個(gè)頁(yè)面中如果有多個(gè)上傳組件的話,那么就會(huì)導(dǎo)致一上來(lái)就會(huì)一次性請(qǐng)求多個(gè)重復(fù)的接口,有什么好點(diǎn)的方法嗎,如果不放在vuex中的話。

解決方法:

這種情況下的 getSignature 最好是 Singleton 的,可以寫(xiě)個(gè)模塊導(dǎo)出。mixin 里的 getSignatrue 都直接引用或調(diào)用這個(gè) Singleton 的 getSignature。

因?yàn)榇蠹叶颊{(diào)同一個(gè) Signature,那么可以在這里做一些判斷和處理,基本思路就是,

  • 有緩存拿緩存
  • 沒(méi)緩存判斷如果是第 1 個(gè)請(qǐng)求的,就去請(qǐng)求遠(yuǎn)端
  • 如果不是第 1 個(gè)請(qǐng)求的,就等

 

let cache = null;
let count = 0;

async function delay(ms = 200) {
    return new Promise(resolve => setTimeout(resolve, ms));
}

export async function getSignature() {
    if (cache) { return cache; }

    if (count++) {
        // 如果有計(jì)數(shù)說(shuō)明自己不是第 1 個(gè),就等。注意這里判斷的是加之前的 count
        // 循環(huán)里最好再加個(gè)超時(shí)判斷
        while (!cache) { await delay(); }
    } else {
        // 是第 1 個(gè)就去請(qǐng)求
        // 如果這里有可能會(huì)拋異常,拋異常也不要漏了 count--
        // (這個(gè)示例代碼沒(méi)做容錯(cuò),自己加)
        cache = await fetchSignature();
    }

    count--;    // 記得減回去,方便以后如果要刷新 cache 的時(shí)候用
    return cache;
}
 

 

分享到:
標(biāo)簽:Vue
用戶(hù)無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定