axios封装请求方式post,请求类型为query
时间: 2023-08-21 16:01:57 浏览: 158
好的,针对您的问题,可以使用axios封装一个post请求,请求类型为query,代码如下:
```javascript
import axios from 'axios';
const instance = axios.create({
baseURL: 'http://your-api-base-url.com',
timeout: 10000, // 超时时间
headers: {
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
},
});
// 封装post请求
export const postQuery = (url, params) => {
return instance({
url,
method: 'POST',
params,
});
};
```
使用时,只需要调用 `postQuery` 函数,传入url和参数即可:
```javascript
postQuery('/your-api-path', { key: 'value' })
.then(response => {
console.log(response.data);
})
.catch(error => {
console.log(error);
});
```
其中 `params` 就是我们要发送的数据,它会被自动转换成查询字符串(query string)的形式,拼接在URL后面发送给后端。
相关问题
axios封装请求方式post,请求类型为query,一个接口的入参为数组
好的,针对您的问题,可以封装一个post请求,请求类型为query,接口入参为数组的方法。具体实现如下:
```javascript
import axios from 'axios';
const request = axios.create({
baseURL: 'https://example.com',
timeout: 5000,
headers: {
'Content-Type': 'application/json'
}
});
const postQueryWithArray = (url, data) => {
return request({
url,
method: 'post',
params: {
data: JSON.stringify(data)
}
});
};
```
这里通过`axios.create`创建了一个实例,设置了请求超时时间和请求头。然后封装了一个`postQueryWithArray`方法,用于发送post请求,请求类型为query,接口入参为数组。在请求中,通过`params`参数将数组转为JSON字符串,并作为查询参数发送到服务器。使用方法如下:
```javascript
const data = [1, 2, 3];
postQueryWithArray('/api/example', data)
.then(res => {
console.log(res.data);
})
.catch(err => {
console.error(err);
});
```
其中`/api/example`是接口地址,`data`是需要发送的数组。注意,这里使用`JSON.stringify`将数组转为JSON字符串,因为在query类型的请求中,数组无法直接作为查询参数发送。
vue封装axios请求
在Vue中使用axios进行网络请求是非常常见的。我们可以对axios进行封装来方便地在Vue中使用。这里提供一个例子,包括axios的安装、请求拦截器、设置请求超时时间以及post请求头的设置。
首先,我们需要安装axios,可以通过npm install axios命令来进行安装。后,我们可以在Vue项目中的main.js文件中引入axios,并且将其挂载到Vue原型上,这样在组件中就可以通过this.$http来进行访问。接下来,我们可以封装一个request函数,封装axios的请求拦截器、设置请求超时时间以及post请求头的设置。
下面是一个简单的封装axios请求的例子:
1. 安装axios
```
npm install axios
```
2. 在main.js中引入axios并挂载到Vue原型上
```
import axios from 'axios'
Vue.prototype.$http = axios
```
3. 封装request函数
```
import axios from 'axios'
import store from '@/store/index'
// 创建axios实例
const service = axios.create({
timeout: 10000 // 请求超时时间
})
// 请求拦截器
service.interceptors.request.use(
config => {
// 每次发送请求之前判断vuex中是否存在token
// 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况
// 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断
const token = store.state.token
token && (config.headers.Authorization = token)
return config
},
error => {
return Promise.error(error)
}
)
// 响应拦截器
service.interceptors.response.use(
response => {
// 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据
// 否则的话抛出错误
if (response.status === 200) {
return Promise.resolve(response.data)
} else {
return Promise.reject(response)
}
},
error => {
// 服务器返回不是 2 开头的情况,会进入这个回调
// 可以根据后台返回的状态码进行不同的操作
if (error.response.status) {
switch (error.response.status) {
// 401: 未登录
// 未登录则跳转登录页面,并携带当前页面的路径
// 在登录成功后返回当前页面,这一步需要在登录页操作。
case 401:
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
})
break
// 403 token过期
// 登录过期对用户进行提示
// 清除本地token和清空vuex中token对象
// 跳转登录页面
case 403:
Toast({
message: '登录过期,请重新登录',
duration: 1000,
forbidClick: true
})
// 清除token
localStorage.removeItem('token')
store.commit('loginSuccess', null)
// 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面
setTimeout(() => {
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
})
}, 1000)
break
// 404请求不存在
case 404:
Toast({
message: '网络请求不存在',
duration: 1500,
forbidClick: true
})
break
// 其他错误,直接抛出错误提示
default:
Toast({
message: error.response.data.message,
duration: 1500,
forbidClick: true
})
}
return Promise.reject(error.response)
}
}
)
export default service
```
4. 在组件中使用request函数
```
import request from '@/utils/request'
// 发送get请求
request.get(url, params).then(res => {
console.log(res)
}).catch(err => {
console.log(err)
})
// 发送post请求
request.post(url, data).then(res => {
console.log(res)
}).catch(err => {
console.log(err)
})
```
--相关问题--:
阅读全文