小編給大家分享一下vue中axios二次封裝的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
10多年的安圖網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網站的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整安圖建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。成都創新互聯公司從事“安圖網站設計”,“安圖網站推廣”以來,每個客戶項目都認真落實執行。
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。
我們做項目時,雖然axios也可以直接拿來用,但是對接口比較零散,不太好進行維護,也會產生大量的重復代碼,所以我在這對axios進行了統一接口處理
第一步,先在src中的公共文件夾中如utils里新建request.js文件
import axios from 'axios' import router from '@/router/routers' import { Notification, MessageBox } from 'element-ui' import store from '../store' import { getToken } from '@/utils/auth' import Config from '@/config' import {baseUrl} from '@/utils/env' // 創建axios實例 const service = axios.create({ baseURL: baseUrl, // api 的 base_url // baseURL: process.env.BASE_API, // api 的 base_url timeout: Config.timeout // 請求超時時間 }) // request攔截器 service.interceptors.request.use( config => { if (getToken()) { config.headers['Authorization'] = 'Bearer ' + getToken() // 讓每個請求攜帶自定義token 請根據實際情況自行修改 } config.headers['Content-Type'] = 'application/json' return config }, error => { // Do something with request error console.log(error) // for debug Promise.reject(error) } ) // response 攔截器 service.interceptors.response.use( response => { const code = response.status console.log(response) if (code < 200 || code > 300) { Notification.error({ title: response.message }) return Promise.reject('error') } else { return response.data } }, error => { let code = 0 try { code = error.response.data.status } catch (e) { if (error.toString().indexOf('Error: timeout') !== -1) { Notification.error({ title: '網絡請求超時', duration: 2500 }) return Promise.reject(error) } if (error.toString().indexOf('Error: Network Error') !== -1) { Notification.error({ title: '網絡請求錯誤', duration: 2500 }) return Promise.reject(error) } } if (code === 401) { MessageBox.confirm( '登錄狀態已過期,您可以繼續留在該頁面,或者重新登錄', '系統提示', { confirmButtonText: '重新登錄', cancelButtonText: '取消', type: 'warning' } ).then(() => { store.dispatch('LogOut').then(() => { location.reload() // 為了重新實例化vue-router對象 避免bug }) }) } else if (code === 403) { router.push({ path: '/401' }) } else { const errorMsg = error.response.data.message if (errorMsg !== undefined) { Notification.error({ title: errorMsg, duration: 2500 }) } } return Promise.reject(error) } ) export default service
代碼解讀:
將接口統一放到單獨的文件中如我的
引入request.js
第三步,
在頁面使用
好了,這就是axios的二次封裝
以上是“vue中axios二次封裝的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!
分享名稱:vue中axios二次封裝的示例分析
網頁網址:http://vcdvsql.cn/article38/pccdpp.html
成都網站建設公司_創新互聯,為您提供小程序開發、網站收錄、網站策劃、、面包屑導航、全網營銷推廣
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯