Vue和Axios是前端開(kāi)發(fā)中常用的兩個(gè)工具,Vue用于構(gòu)建用戶界面,而Axios用于向后端API進(jìn)行數(shù)據(jù)請(qǐng)求和交互。尤其是在當(dāng)下Web應(yīng)用程序中,前端與后端的交互日益頻繁,因此封裝一個(gè)Axios是至關(guān)重要的。
Vue中,將Axios封裝成一個(gè)插件可以便于我們?cè)诮M件中使用。使用Vue插件可以讓代碼整潔、易懂,而且可以讓我們?cè)诮M件中更容易地調(diào)用與Axios相關(guān)的方法。
首先,需要在項(xiàng)目中安裝Axios,使用npm安裝Axios,命令如下:
npm install axios --save
安裝成功之后,在項(xiàng)目中使用Axios。
通常在API請(qǐng)求過(guò)程中,為了減少代碼冗余并且減小維護(hù)成本,我們通常會(huì)對(duì)Axios進(jìn)行封裝。下面是一個(gè)典型的Axios封裝示例:
import axios from 'axios'
import { Message } from 'element-ui'
axios.defaults.baseURL = process.env.VUE_APP_API_URL
axios.interceptors.request.use(
function(config) {
const token = sessionStorage.getItem('token')
if (token) {
// Bearer是JWT的請(qǐng)求頭標(biāo)識(shí)字段
config.headers.Authorization = `Bearer ${token}`
}
return config
},
function(error) {
return Promise.reject(error)
}
)
axios.interceptors.response.use(
function(response) {
return response
},
function(error) {
if (error.response.status === 401) {
Message.error('登錄信息已過(guò)期,請(qǐng)重新登錄')
sessionStorage.removeItem('userInfo')
sessionStorage.removeItem('token')
window.location.href = '/'
}
return Promise.reject(error)
}
)
const request = (method, url, data) =>{
return axios({
method,
url,
data
})
}
export default request
以上代碼完成了請(qǐng)求頭的設(shè)置、請(qǐng)求攔截器、響應(yīng)攔截器、請(qǐng)求方法封裝等。在其中,我們使用了Message組件來(lái)展示錯(cuò)誤信息并做了登錄信息過(guò)期的處理。
在使用中,我們可以簡(jiǎn)單地進(jìn)行請(qǐng)求,例如:
import request from '@/utils/request'
export const login = data => {
return request('POST', '/api/user/login', data)
}
以上提供了一個(gè)簡(jiǎn)單的Axios封裝示例,但是實(shí)際情況可能會(huì)更加復(fù)雜。相信通過(guò)這個(gè)示例,你已經(jīng)掌握了大部分Axios的封裝方法,可以開(kāi)始應(yīng)用Axios進(jìn)行項(xiàng)目開(kāi)發(fā)了。