vue3網(wǎng)絡(luò)請(qǐng)求添加loading過(guò)程
vue3網(wǎng)絡(luò)請(qǐng)求添加loading
全局添加
import axios from 'axios' import { ElLoading } from 'element-plus' let loadingRequestCount = 0 let loadingInstance const showLoading = () => { if (loadingRequestCount === 0) { loadingInstance = ElLoading.service({ target: '#app' }) } loadingRequestCount += 1 } const hideLoading = () => { if (loadingRequestCount <= 0) return loadingRequestCount -= 1 if (loadingRequestCount === 0) { // nextTick(() => { loadingInstance.close() // }) } } const service = axios.create({ // baseURL: process.env.BASE_API, baseURL: 'http://localhost:4500', timeout: 3 * 1000 }) // 請(qǐng)求攔截器 service.interceptors.request.use( (config) => { showLoading() return config }, (error) => { Promise.reject(error) } ) service.interceptors.response.use( (res) => { hideLoading() }, (error) => { hideLoading() } ) export default service
ElLoading.service({ target: ‘#app' })
target添加類名就是為某個(gè)類名添加loading。全局就是#app
局部添加
或者 按鈕直接添加
let loadingInstance: any // 添加loading loadingInstance = ElLoading.service({ target: '.container_box' }) // 關(guān)閉laoding loadingInstance.close()
vue優(yōu)化:添加請(qǐng)求loading效果
目標(biāo):統(tǒng)一在每次請(qǐng)求后臺(tái)時(shí),添加 loading 效果
背景:有時(shí)候因?yàn)榫W(wǎng)絡(luò)原因,一次請(qǐng)求的結(jié)果可能需要一段時(shí)間后才能回來(lái), 此時(shí),需要給用戶 添加 loading 提示。
添加 loading 提示的好處:
- 節(jié)流處理:防止用戶在一次請(qǐng)求還沒回來(lái)之前,多次進(jìn)行點(diǎn)擊,發(fā)送無(wú)效請(qǐng)求
- 友好提示:告知用戶,目前是在加載中,請(qǐng)耐心等待,用戶體驗(yàn)會(huì)更好
實(shí)操步驟
1.請(qǐng)求攔截器中,每次請(qǐng)求,打開 loading
// 自定義配置 - 請(qǐng)求/響應(yīng) 攔截器 // 添加請(qǐng)求攔截器 instance.interceptors.request.use(function (config) { // 在發(fā)送請(qǐng)求之前做些什么 // 開啟loading,禁止背景點(diǎn)擊 (節(jié)流處理,防止多次無(wú)效觸發(fā)) Toast.loading({ message: '加載中...', forbidClick: true, // 禁止背景點(diǎn)擊 loadingType: 'spinner', // 配置loading圖標(biāo) duration: 0 // 不會(huì)自動(dòng)消失 }) // 只要有token,就在請(qǐng)求時(shí)攜帶,便于請(qǐng)求需要授權(quán)的接口 const token = store.getters.token if (token) { config.headers['Access-Token'] = token config.headers.platform = 'H5' } return config }, function (error) { // 對(duì)請(qǐng)求錯(cuò)誤做些什么 return Promise.reject(error) })
- 2.響應(yīng)攔截器中,每次響應(yīng),關(guān)閉 loading
- 3.請(qǐng)求時(shí),打開 loading
// 添加響應(yīng)攔截器 instance.interceptors.response.use(function (response) { // 2xx 范圍內(nèi)的狀態(tài)碼都會(huì)觸發(fā)該函數(shù)。 // 對(duì)響應(yīng)數(shù)據(jù)做點(diǎn)什么 (默認(rèn)axios會(huì)多包裝一層data,需要響應(yīng)攔截器中處理一下) const res = response.data if (res.status !== 200) { // 給錯(cuò)誤提示, Toast 默認(rèn)是單例模式,后面的 Toast調(diào)用了,會(huì)將前一個(gè) Toast 效果覆蓋 // 同時(shí)只能存在一個(gè) Toast Toast(res.message) // 拋出一個(gè)錯(cuò)誤的promise return Promise.reject(res.message) } else { // 正確情況,直接走業(yè)務(wù)核心邏輯,清除loading效果 Toast.clear() } return res }, function (error) { // 超出 2xx 范圍的狀態(tài)碼都會(huì)觸發(fā)該函數(shù)。 // 對(duì)響應(yīng)錯(cuò)誤做點(diǎn)什么 return Promise.reject(error) })
如果需要多個(gè)Toast,則需要配置,但一般不用
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決vue2.x中數(shù)據(jù)渲染以及vuex緩存的問(wèn)題
本篇文章主要介紹了vue2.x中請(qǐng)求之前數(shù)據(jù)顯示以及vuex緩存的問(wèn)題,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07vue通過(guò)v-html指令渲染的富文本無(wú)法修改樣式的解決方案
這篇文章主要介紹了vue通過(guò)v-html指令渲染的富文本無(wú)法修改樣式的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05vue基礎(chǔ)之事件簡(jiǎn)寫、事件對(duì)象、冒泡、默認(rèn)行為、鍵盤事件實(shí)例分析
這篇文章主要介紹了vue基礎(chǔ)之事件簡(jiǎn)寫、事件對(duì)象、冒泡、默認(rèn)行為、鍵盤事件,結(jié)合實(shí)例形式分析了vue.js事件簡(jiǎn)寫、冒泡及阻止冒泡等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03Vue數(shù)據(jù)驅(qū)動(dòng)模擬實(shí)現(xiàn)1
這篇文章主要介紹了Vue數(shù)據(jù)驅(qū)動(dòng)模擬實(shí)現(xiàn)的相關(guān)資料,允許采用簡(jiǎn)潔的模板語(yǔ)法聲明式的將數(shù)據(jù)渲染進(jìn)DOM,且數(shù)據(jù)與DOM綁定在一起,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01vue 使用element-ui中的Notification自定義按鈕并實(shí)現(xiàn)關(guān)閉功能及如何處理多個(gè)通知
這篇文章主要介紹了vue 使用element-ui中的Notification自定義按鈕并實(shí)現(xiàn)關(guān)閉功能及如何處理多個(gè)通知,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08vue-cli 引入jQuery,Bootstrap,popper的方法
這篇文章主要介紹了vue-cli 引入jQuery,Bootstrap,popper的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09vue cli3.0 引入eslint 結(jié)合vscode使用
這篇文章主要介紹了vue cli3.0 引入eslint 結(jié)合vscode使用,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05一文帶你深入了解V-model實(shí)現(xiàn)數(shù)據(jù)雙向綁定
這篇文章主要為大家詳細(xì)介紹了V-model實(shí)現(xiàn)數(shù)據(jù)雙向綁定的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12