亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Vue全局loading及錯誤提示的思路與實現

2019-11-19 11:03:31
字體:
來源:轉載
供稿:網友

前言

近期項目馬上上線,前兩天產品提個需求,加個全局loading,我這半路出家的vue選手,有點懵逼,這玩意還是第一次,但是作為一個初級的前端切圖仔,這個東西是必須會的,花了五分鐘思考了一下,然后動鍵盤碼出來 ,今天總結一下,與各位分享交流,有錯誤還請各位指出。

思路

我們項目請求使用的是axios,那么我們就在請求前后進行攔截,添加我們需要的東西,然后通信控制loading,通信方式我就不寫了,有個老哥寫的不錯,可以去看看傳送門

代碼實現

首先對axios進行封裝 如果你想進行全局錯誤提醒 也可以在攔截的代碼進行操作 具體代碼看下面

/** * axios 配置模塊 * @module config * @see utils/request*//** * axios具體配置對象 * @description 包含了基礎路徑/請求前后對數據對處理,自定義請求頭的設置等 */const axiosConfig = { baseURL: process.env.RESTAPI_PREFIX, // 請求前的數據處理 // transformRequest: [function (data) { // return data // }], // 請求后的數據處理 // transformResponse: [function (data) { // return data // }], // 自定義的請求頭 // headers: { // 'Content-Type': 'application/json' // }, // 查詢對象序列化函數 // paramsSerializer: function (params) { // return qs.stringify(params) // }, // 超時設置s timeout: 10000, // 跨域是否帶Token 項目中加上會出錯 // withCredentials: true, // 自定義請求處理 // adapter: function(resolve, reject, config) {}, // 響應的數據格式 json / blob /document /arraybuffer / text / stream responseType: 'json', // xsrf 設置 xsrfCookieName: 'XSRF-TOKEN', xsrfHeaderName: 'X-XSRF-TOKEN', // 下傳和下載進度回調 onUploadProgress: function (progressEvent) { Math.round(progressEvent.loaded * 100 / progressEvent.total) }, onDownloadProgress: function (progressEvent) { Math.round(progressEvent.loaded * 100 / progressEvent.total) }, // 最多轉發數,用于node.js maxRedirects: 5, // 最大響應數據大小 maxContentLength: 2000, // 自定義錯誤狀態碼范圍 validateStatus: function (status) { return status >= 200 && status < 300 } // 用于node.js // httpAgent: new http.Agent({ keepAlive: true }), // httpsAgent: new https.Agent({ keepAlive: true })}/** 導出配置模塊 */export default axiosConfig

開始構建請求對象

const request = axios.create(config)

請求之前攔截

// 請求攔截器request.interceptors.request.use( config => { // 觸發loading效果 store.dispatch('SetLoding', true) return config }, error => { return Promise.reject(error) })

請求后攔截

// 返回狀態判斷(添加響應攔截器)request.interceptors.response.use( (res) => { // 加載loading store.dispatch('SetLoding', false) // 如果數據請求失敗 let message = '' let prefix = res.config.method !== 'get' ? '操作失?。? : '請求失敗:' switch (code) {  case 400: message = prefix + '請求參數缺失'; break  case 401: message = prefix + '認證未通過'; break  case 404: message = prefix + '此數據不存在'; break  case 406: message = prefix + '條件不滿足'; break  default: message = prefix + '服務器出錯了'; break } let error = new Error(message) if (tip) {  errorTip(vueInstance, error, message) } let result = { ...res.data, error: error } return result }, (error, a, b) => { store.dispatch('SetLoding', false) process.env.NODE_ENV !== 'production' && console.log(error) return { data: null, code: 500, error: error } })

通信

我這邊通信用的是Vuex,其他方式類似

 state: { loading: 0 }, mutations: { SET_LOADING: (state, loading) => {  loading ? ++state.loading : --state.loading }, CLEAN_LOADING: (state) => {  state.loading = 0 } }, actions: { SetLoding ({ commit }, boolean) {  commit('SET_LOADING', boolean) }, CLEANLOADING ({commit}) {  commit('CLEAN_LOADING') } }, getters: { loading (state) {  return state.loading } }

state采用計數方式能夠避免一個頁面可能同時有多個ajax請求,導致loading閃現多次,這樣就會在所有ajax都結束后才隱藏loading,不過有個很重要的地方需要注意,每一個路由跳轉時無論ajax是否結束,都必須把state的值設置為0,具體下面的代碼

router.beforeEach((to, from, next) => { store.dispatch('CLEANLOADING') next()})

全局的loading我這邊是加在home.vue里,由于我這個項目是后臺管理,可以加在layout.vue,其實都差不多

<div class="request-loading" :class="{'request-loading-show':loading}"> <div class="request-loading-main" ></div></div>
import { mapGetters } from 'vuex'export default {  data () {  } computed: { ...mapState(['loading])  }<scrirpt lang="scss" scoped>//這個我就不寫了 loading樣式不同 我們代碼也就不同</script>

大致代碼和思路就是這樣 可能會有錯誤 還希望各位批評指正

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美中文日韩在线v日本| 久久深夜福利免费观看| 国内精品久久久久| 日韩欧美主播在线| 插插插亚洲综合网| 欧美久久久精品| 欧美专区在线播放| 国产999精品久久久| xxx一区二区| 欧美成人精品在线视频| 国内精品小视频| 亚洲精品第一国产综合精品| 日韩va亚洲va欧洲va国产| 精品国模在线视频| 国产美女直播视频一区| 中文字幕在线观看日韩| 性夜试看影院91社区| 欧美成人在线免费| 日韩av一区二区在线| 欧美视频一区二区三区…| 68精品国产免费久久久久久婷婷| 欧美激情高清视频| 亚洲美女视频网站| 亚洲成人国产精品| 一区二区三区动漫| 国产噜噜噜噜久久久久久久久| 国产ts人妖一区二区三区| 欧美国产日韩一区二区| 欧美国产日韩二区| 国产精品 欧美在线| 国产一区二区三区视频| 亚洲第一精品夜夜躁人人躁| 精品偷拍各种wc美女嘘嘘| 欧美性xxxxxx| 日韩在线一区二区三区免费视频| 日韩美女视频免费在线观看| 欧美激情一级二级| 欧美日韩亚洲天堂| 欧美性精品220| 久久香蕉国产线看观看av| 久久久www成人免费精品张筱雨| 精品国产91久久久久久老师| 精品少妇一区二区30p| 欧美午夜激情在线| yw.139尤物在线精品视频| 日韩国产精品一区| 日本伊人精品一区二区三区介绍| 亚洲的天堂在线中文字幕| 永久免费毛片在线播放不卡| 91人成网站www| 欧美性猛交xxxx久久久| 福利视频第一区| 国产精品久久久久久久久久久久久| 97超级碰碰碰| 欧美精品少妇videofree| 亚洲摸下面视频| 久久夜色精品国产亚洲aⅴ| 久久综合国产精品台湾中文娱乐网| 青青草原成人在线视频| 亚洲xxx大片| 日韩精品视频免费| 国产精品96久久久久久又黄又硬| 精品视频中文字幕| 91精品国产91久久久久久吃药| 97精品欧美一区二区三区| 中文字幕日本精品| 国产在线高清精品| 欧美色道久久88综合亚洲精品| 日韩精品在线视频美女| 精品久久久一区二区| 日韩精品免费在线| 亚洲护士老师的毛茸茸最新章节| 国产视频亚洲视频| 亚洲人成网7777777国产| 亚洲成人av中文字幕| 成人精品一区二区三区电影黑人| 欧美不卡视频一区发布| 欧美又大又硬又粗bbbbb| 欧美美最猛性xxxxxx| 91综合免费在线| 亚洲成人中文字幕| 国产精品老女人精品视频| 亚洲午夜久久久久久久| 国产精品极品尤物在线观看| 久久视频这里只有精品| 欧洲永久精品大片ww免费漫画| 成人h片在线播放免费网站| 在线电影av不卡网址| 色偷偷av亚洲男人的天堂| 国产一区二区三区直播精品电影| 亚洲欧美制服中文字幕| 色噜噜久久综合伊人一本| 亚洲欧洲日本专区| 国产拍精品一二三| 欧美日韩亚洲精品内裤| 久久精品99久久香蕉国产色戒| 最近2019免费中文字幕视频三| 北条麻妃一区二区三区中文字幕| zzijzzij亚洲日本成熟少妇| 久久久亚洲福利精品午夜| 黄色精品一区二区| 久久夜精品香蕉| 97视频免费观看| 精品中文字幕在线2019| 亚洲精品永久免费精品| 91chinesevideo永久地址| 国产精品99导航| 欧美成人午夜影院| 亚洲成人av片在线观看| 在线视频亚洲欧美| 97在线日本国产| 日韩av免费在线| 91精品国产91| 国产欧美日韩精品丝袜高跟鞋| 久久久精品久久| 日韩在线免费av| 成人福利在线观看| 国产日韩欧美在线播放| 久久国产精品影视| 欧美激情综合色综合啪啪五月| 国产午夜精品久久久| 久久九九国产精品怡红院| 欧洲中文字幕国产精品| 91免费欧美精品| 成人av资源在线播放| 欧美午夜视频一区二区| 中文字幕亚洲一区| 另类专区欧美制服同性| 亚洲毛片在线免费观看| 国产精品999999| 亚洲国产精品久久久久久| 中文字幕九色91在线| 97在线视频免费| 欧美一区二区三区免费观看| 亚洲a成v人在线观看| 亚洲欧美在线第一页| 日韩美女免费视频| 久久九九有精品国产23| 亚洲视频国产视频| 亚洲www永久成人夜色| 成人av.网址在线网站| 欧美激情喷水视频| 日韩在线观看精品| 欧美成在线观看| 亚洲欧洲日产国码av系列天堂| 亚洲自拍偷拍在线| 国产精品高清在线观看| 久久影院资源站| 2019国产精品自在线拍国产不卡| 国产精品免费观看在线| 国产网站欧美日韩免费精品在线观看| 国产欧美一区二区| 欧美又大又硬又粗bbbbb| 欧美成aaa人片在线观看蜜臀| 成人美女免费网站视频| 国产精品久久99久久| 日本三级久久久| 欧美一级免费看| 97人洗澡人人免费公开视频碰碰碰| 日韩女优人人人人射在线视频| 狠狠躁夜夜躁久久躁别揉| 国产69精品久久久久久| 久久精品中文字幕一区| 国产亚洲激情视频在线|