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

一文教你如何優(yōu)雅的控制全局loading的顯示

 更新時(shí)間:2022年01月09日 15:59:44   作者:秦老六  
在我們的平時(shí)的工作中,在前后端交互的時(shí)候,為了提高頁(yè)面的觀賞性和用戶的體驗(yàn),我們會(huì)在頁(yè)面上添加loading來(lái)阻止用戶操作來(lái)等待接口的返回,這篇文章主要給大家介紹了關(guān)于如何優(yōu)雅的控制全局loading顯示的相關(guān)資料,需要的朋友可以參考下

在很多后臺(tái)管理系統(tǒng)中,發(fā)送請(qǐng)求的時(shí)候,需要打開一個(gè)loading,收到響應(yīng)后,需要關(guān)閉這個(gè)loading,對(duì)于這種通用的邏輯,我一般是在axios攔截器中做這種處理,因?yàn)椴皇敲總€(gè)請(qǐng)求都需要全局顯示loading,所以我在axios config中添加了一個(gè)標(biāo)記showLoading, 用于標(biāo)記發(fā)送請(qǐng)求之前是否需要顯示loading,自然收到響應(yīng)后,根據(jù)這個(gè)標(biāo)記確定是否需要關(guān)閉loading,在axios攔截器中的代碼如下:

axios.interceptors.request.use(
  (config) => {
    // config中不設(shè)置showLoading這個(gè)字段或者這個(gè)字段為true時(shí),代表需要全局顯示loading
    if (config.headers.showLoading !== false) {
      // 全局顯示loading
      Loading.showLoading();
    }
    return config;
  },
  (err) => {
    return Promise.reject(err);
  },
);

instance.interceptors.response.use(
  (response) => {
    const { config: { headers } } = response;
    if (headers.showLoading !== false) {
      // 關(guān)閉全局的loading
      Loading.hideLoading();
    }
    return data;
  }
);

我自己自然覺(jué)得上面那個(gè)實(shí)現(xiàn)自然滿足要求了,但是偶然一次和后端同事聊起這個(gè)問(wèn)題,后端同事說(shuō),這個(gè)前端的標(biāo)記(showLoading)怎么能傳遞給后端服務(wù)器了,并且還說(shuō),如果是他和我對(duì)接,絕對(duì)不允許我這么做。然后我就懵逼了,因?yàn)橄氩坏浇鉀Q辦法。

直到后來(lái)了解到洋蔥模型,其實(shí)請(qǐng)求,響應(yīng)天然的適用洋蔥模型,如果給axios添加上洋蔥模型,這個(gè)問(wèn)題就自然而然解決了啊。下面講解如何給axios添加洋蔥模型,如果有了洋蔥模型,axios攔截器就沒(méi)有必要了,因?yàn)檠笫[模型比axios攔截器更好用。

  • 聲明MiddleWareManager類,這個(gè)類是洋蔥模型的具體實(shí)現(xiàn),代碼如下。
// 中間件管理器,用于添加,刪除中間件。
// 另外這個(gè)添加的中間件給誰(shuí)用,也需要用參數(shù)(job)保存起來(lái)。
class MiddleWareManager {
  // 添加的中間件是給誰(shuí)用的,我們用job標(biāo)識(shí),如果中間件是給axios用,那么這個(gè)job就是axios方法。
  // middleWares用來(lái)保存中間件。
  // job和中間件都是返回Promise對(duì)象的方法。
  // 其中,job接受一個(gè)參數(shù)config,由最后一個(gè)中間件傳遞。
  // 中間件接受兩個(gè)參數(shù),一個(gè)是他之前的中間件傳遞的config,一個(gè)是執(zhí)行下一個(gè)中間件的方法。
  constructor(job) {
    // 這里默認(rèn)加上axios請(qǐng)求
    this.job = job;
    this.middleWares = [];
  }

  use(middleWare) {
    this.middleWares.unshift(middleWare);
    return this;
  }

  remove(middleWare) {
    const index = this.middleWares.indexOf(middleWare);
    this.middleWares.splice(index, 1);
    return this;
  }

  run(config) {
    const { length } = this.middleWares;
    function innerRun(config, index) {
      // 如果中間件已經(jīng)執(zhí)行完畢,這直接job函數(shù)。
      if (index >= length) {
        return this.job(config);
      }
      // 否則執(zhí)行下一個(gè)中間件函數(shù)
      return this.middleWares[index](config, (config) => innerRun(config, index++));
    }
    innerRun(config, 0);
  }
}
  • MiddleWareManager已經(jīng)實(shí)現(xiàn),接下來(lái)是講解如何將MiddleWareManager和axios組合到一起使用。我們會(huì)定義一個(gè)request方法,當(dāng)我們需要發(fā)送請(qǐng)求的時(shí)候,我們就統(tǒng)一調(diào)用request方法。
// middleWare1用于處理是否需要全局的顯示loading
async function middleWare1(config, next) {
  // 查看config中是否有showLoading標(biāo)記,如果沒(méi)有或者為true, 則需要全局顯示loading, 
  // 當(dāng)接收到響應(yīng)后,自然需要關(guān)閉loading
  // 自然收到響應(yīng)后,根據(jù)這個(gè)標(biāo)記確定是否需要關(guān)閉loading
  const { showLoading, ...rest } = config;
  if (showLoading !== false) {
    // 顯示loading動(dòng)畫
  }
  const response = await next(rest);
  if (showLoading !== false) {
    // 關(guān)閉動(dòng)畫
  }
  return response;
}

// 組裝MiddleWareManager
const manager = new MiddleWareManager(axios);
manager.use(middleWare1);

// 實(shí)現(xiàn)request方法,用于發(fā)送請(qǐng)求
function request(config) {
  return manager.run(config);
}
  • 當(dāng)我們發(fā)送請(qǐng)求需要全局打開loading時(shí),像如下做
request({
  url: 'xxx',
  method: 'get'
})

這樣在發(fā)送請(qǐng)求前,會(huì)自動(dòng)打開loading,當(dāng)接收到響應(yīng)后,會(huì)自動(dòng)關(guān)閉loading. 當(dāng)我們不需要自動(dòng)打開loading的功能時(shí),我們只需要在發(fā)送請(qǐng)求時(shí)在config中添加showLoading: false就可以了,代碼如下

request({
  url: 'xxx',
  method: 'get',
  showLoading: false
})

這樣做是不是滿足了后端同事的要求了呢!并且洋蔥模型也比攔截器使用起來(lái)更加方便,特別是在請(qǐng)求和響應(yīng)中訪問(wèn)相同的變量的時(shí)候。就如我們例子中的showLoading. 當(dāng)然我們也可以把攔截器中的更多功能移到洋蔥模型的中間件中,比如發(fā)送請(qǐng)求時(shí),自動(dòng)添加token。

總結(jié)

到此這篇關(guān)于如何優(yōu)雅的控制全局loading的顯示的文章就介紹到這了,更多相關(guān)控制全局loading顯示內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論