vue日常開發(fā)基礎(chǔ)Axios網(wǎng)絡(luò)庫封裝
引言
首先Axios,一個基于 promise 的 HTTP 庫,可以用在瀏覽器和 node.js 中。
網(wǎng)絡(luò)請求庫無疑是項目開發(fā)中最基礎(chǔ)的建設(shè)了,在這個前后端分離的時代,市面上有不少優(yōu)秀的請求庫,其中Axios就是優(yōu)秀代表之一。
- 攔截請求和響應(yīng)
- 轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
- 自動轉(zhuǎn)換 JSON 數(shù)據(jù)
- 客戶端支持防御 XSRF
- 支持 PromiseAPI
以上是axios的優(yōu)秀點
axios使用
本文是基于Vue項目去使用Axios:
第一步安裝 npm install axios 已經(jīng)邁出了一步,打開我們的package.json文件發(fā)現(xiàn)已經(jīng)安裝成功,
接下來我們?nèi)ゾ唧w實現(xiàn)功能:
1.配置請求基本信息
2.設(shè)置請求攔截器
3.設(shè)置請求響應(yīng)器
實現(xiàn)以上三個方法
配置請求基本信息
//request.js
import axios from 'axios'
// 創(chuàng)建axios實例
const service = axios.create({
// axios中請求配置有baseURL選項,表示請求URL公共部分
baseURL: process.env.VUE_APP_BASE_API,
// 超時
timeout: 20000
})
設(shè)置請求攔截器
在發(fā)送請求之前我們總得做一些事情:
- 是否需要token(如需要的話將每個請求攜帶token)
- 如果是get需要傳遞參數(shù)的話需要將特殊字符過濾掉
// request攔截器
service.interceptors.request.use(
config => {
// 是否需要設(shè)置 token
const isToken = (config.headers || {}).isToken === false
if (getToken() && !isToken) {
config.headers['Authorization'] = 'Bearer ' + getToken() // 讓每個請求攜帶自定義token 請根據(jù)實際情況自行修改
}
// get請求映射params參數(shù)
if (config.method === 'get' && config.params) {
let url = config.url + '?'
for (const propName of Object.keys(config.params)) {
const value = config.params[propName]
var part = encodeURIComponent(propName) + '='
if (value !== null && typeof value !== 'undefined' && value !== '') {
if (typeof value === 'object') {
for (const key of Object.keys(value)) {
let params = propName
// let params = propName + '[' + key + ']'
var subPart = encodeURIComponent(params) + '='
url += subPart + encodeURIComponent(value[key]) + '&'
}
} else {
url += part + encodeURIComponent(value) + '&'
}
}
}
url = url.slice(0, -1)
config.params = {}
config.url = url
}
return config
},
error => {
console.log(error)
Promise.reject(error)
}
)
補充:
encodeURIComponent方法是js提供的一個方法,把字符串作為 URI 組件進行編碼,該方法不會對 ASCII 字母和數(shù)字進行編碼,主要作用是過濾掉特殊字符
設(shè)置請求響應(yīng)器
當數(shù)據(jù)回來的時候,我們也得干一點事情:
- 判斷登錄狀態(tài)
- 錯誤處理
import { Message, MessageBox, Notification } from 'element-ui'
import errorCode from '@/utils/errorCode'
// 響應(yīng)攔截器
service.interceptors.response.use(
res => {
// 未設(shè)置狀態(tài)碼則默認成功狀態(tài)
const code = Number(res.data.code) || 200
// 獲取錯誤信息
const msg = errorCode[code] || res.data.msg || errorCode['default']
if (code === 401) {
MessageBox.confirm(
'登錄狀態(tài)已過期,您可以繼續(xù)留在該頁面,或者重新登錄',
'系統(tǒng)提示',
{
confirmButtonText: '重新登錄',
cancelButtonText: '取消',
type: 'warning'
}
).then(() => {
store.dispatch('LogOut').then(() => {
location.href = '/index'
})
})
} else if (code === 500) {
Message({
message: msg,
type: 'error'
})
return Promise.reject(new Error(msg))
} else if (code !== 200) {
Notification.error({
title: msg
})
return Promise.reject(msg)
} else {
return res.data
}
},
error => {
console.log('err' + error)
let { message } = error
if (message == 'Network Error') {
message = '后端接口連接異常'
} else if (message.includes('timeout')) {
message = '系統(tǒng)接口請求超時'
} else if (message.includes('Request failed with status code')) {
message = '系統(tǒng)接口' + message.substr(message.length - 3) + '異常'
}
Message({
message: message,
type: 'error',
duration: 5 * 1000
})
return Promise.reject(error)
}
)
export default {
'401': '認證失敗,無法訪問系統(tǒng)資源',
'403': '當前操作沒有權(quán)限',
'404': '訪問資源不存在',
'default': '系統(tǒng)未知錯誤,請反饋給管理員'
}
項目中使用
import request from '@/utils/request'
// 登錄方法
export function login(username, password, code, uuid) {
return request({
url: '/auth/admin/login',
method: 'post',
data: { username, password, code, uuid }
})
}
結(jié)尾
此時我們的網(wǎng)絡(luò)庫的基礎(chǔ)版已經(jīng)實現(xiàn),把service進行一個導(dǎo)出,就可以在項目中使用了,這個版本基本可以滿足日常項目的開發(fā),如果需要其他設(shè)置可以另行添加。 擴展:
- axios取消重復(fù)請求
- axios無感token刷新
以上也是比較常見的場景,在本文注重實現(xiàn)基礎(chǔ)版網(wǎng)絡(luò)庫,日后需要對以上的場景進行探索。完結(jié)撒花~??
export default service
以上就是vue日常開發(fā)基礎(chǔ)Axios網(wǎng)絡(luò)庫封裝的詳細內(nèi)容,更多關(guān)于vue開發(fā)Axios網(wǎng)絡(luò)庫封裝的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue基于Element按鈕權(quán)限實現(xiàn)方案
這篇文章主要介紹了vue基于Element按鈕權(quán)限實現(xiàn)方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
vue 跳轉(zhuǎn)到其他頁面并關(guān)閉當前頁面的實現(xiàn)代碼
我在做一個調(diào)用虛擬機錄屏的一個操作,需要在瀏覽器頁面上,點擊按鈕后,關(guān)閉當前頁面里的某一個頁面,并且打開瀏覽器新頁面是虛擬機的頁面,本文給大家介紹vue 跳轉(zhuǎn)到其他頁面并關(guān)閉當前頁面的實現(xiàn)代碼,感興趣的朋友一起看看吧2023-09-09
Vue+Element UI+Lumen實現(xiàn)通用表格分頁功能
這篇文章主要介紹了Vue+Element UI+Lumen實現(xiàn)通用表格分頁功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
element?ui富文本編輯器的使用效果與步驟(quill-editor)
富文本編輯器在任何項目中都會用到,在Element中我們推薦vue-quill-editor組件,下面這篇文章主要給大家介紹了關(guān)于element?ui富文本編輯器的使用效果與步驟(quill-editor)的相關(guān)資料,需要的朋友可以參考下2022-10-10
Vue數(shù)據(jù)監(jiān)聽器watch和watchEffect的使用
今天我們來學(xué)習(xí)一下watch監(jiān)聽器和它的好兄弟watchEffect監(jiān)聽器。這個相對來說比較簡單,用的不是很多,當然了,根據(jù)自己的項目情況自行決定使用,希望對大家有所幫助2023-02-02
Vue3使用defineAsyncComponent實現(xiàn)異步組件加載的代碼示例
在 Vue 3 中,異步組件加載是一種優(yōu)化應(yīng)用性能的重要手段,通過異步加載組件,可以減少初始加載時的資源體積,從而提升應(yīng)用的加載速度和用戶體驗,本文將詳細介紹如何使用 defineAsyncComponent 實現(xiàn)異步組件加載,并提供相關(guān)的代碼示例,需要的朋友可以參考下2025-03-03

