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