vue封装axios
时间: 2023-02-19 15:47:17 浏览: 34
在 Vue 中封装 axios 通常是指封装 axios 的请求方法并在组件中使用。你可以将 axios 封装到一个单独的模块中,并在需要的组件中导入使用。
首先,安装 axios:
```
npm install axios
```
然后,创建一个 axios.js 文件,在文件中封装 axios 的请求方法:
```
import axios from 'axios'
export default function (url, data = {}, type = 'GET') {
return new Promise(function (resolve, reject) {
let promise
if (type === 'GET') {
// 准备 url query 参数数据
let dataStr = '' // 数据拼接字符串
Object.keys(data).forEach(key => {
dataStr += key + '=' + data[key] + '&'
})
if (dataStr !== '') {
dataStr = dataStr.substring(0, dataStr.lastIndexOf('&'))
url = url + '?' + dataStr
}
// 发送 get 请求
promise = axios.get(url)
} else {
// 发送 post 请求
promise = axios.post(url, data)
}
promise.then(function (response) {
// 成功了调用resolve()
resolve(response.data)
}).catch(function (error) {
//失败了调用reject()
reject(error)
})
})
}
```
在需要使用的组件中导入并使用这个方法:
```
import axios from './axios'
export default {
methods: {
getData () {
axios('/api/data').then(res => {
console.log(res)
})
}
}
}
```
你还可以在封装的方法中统一处理错误,例如响应状态码为 401 时跳转到登录页面。
希望这能帮到你!
阅读全文