vue-axios携带不同参数的总结

1.URL参数

URL参数直接附加在URL后面,通常用于GET请求。

复制代码
axios.get('/user?id=12345&name=John')
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.error(error);
  });

2.查询参数

查询参数通常用在GET请求中,可以通过params属性传递。

复制代码
axios.get('/user', {
  params: {
    id: 12345,
    name: 'John'
  }
})
.then(response => {
  console.log(response.data);
})
.catch(error => {
  console.error(error);
});

3.POST请求体数据

在POST请求中,通常将数据放在请求体中。可以通过data属性传递JSON对象。

复制代码
axios.post('/user', {
  id: 12345,
  name: 'John'
})
.then(response => {
  console.log(response.data);
})
.catch(error => {
  console.error(error);
});

4.FormData数据(文件上传等)

对于需要上传文件或其他非JSON数据的场景,可以使用FormData

复制代码
const formData = new FormData();
formData.append('file', fileInput.files[0]); // fileInput是<input type="file">元素
formData.append('id', '12345');
formData.append('name', 'John');

axios.post('/upload', formData, {
  headers: {
    'Content-Type': 'multipart/form-data' // 不设置时,Axios会自动设置,但仍需明确指出以避免潜在问题
  }
})
.then(response => {
  console.log(response.data);
})
.catch(error => {
  console.error(error);
});

5.URL编码的表单数据(application/x-www-form-urlencoded)

对于需要使用application/x-www-form-urlencoded格式的POST请求,可以使用URLSearchParams

复制代码
const params = new URLSearchParams();
params.append('id', '12345');
params.append('name', 'John');

axios.post('/user', params.toString(), {
  headers: {
    'Content-Type': 'application/x-www-form-urlencoded' // 需要明确设置Content-Type头信息
  }
})
.then(response => {
  console.log(response.data);
})
.catch(error => {
  console.error(error);
});

或者使用qs库将对象转换为查询字符串:

复制代码
import qs from 'qs'; // 首先需要安装qs库:npm install qs
const data = qs.stringify({ id: '12345', name: 'John' }); // 使用qs库转换对象为查询字符串格式的字符串
axios.post('/user', data, { 
  headers: { 'Content-Type': 'application/x-www-form-urlencoded' } 
})...; // 同上处理响应等。
相关推荐
user205855615181317 分钟前
Windows 项目安装时报 `node-sass` 错误,如何快速处理
前端
LiaCode18 分钟前
Redis 在生产项目的使用
前端·后端
LiaCode23 分钟前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战24 分钟前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
风骏时光牛马36 分钟前
# Ruby基于Rails框架实现多角色权限管理与数据分页查询完整实战代码案例
前端
weedsfly38 分钟前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
xiaodaoluanzha43 分钟前
迄今為止,最簡單的編程語言 Nolang
前端·后端
Csvn1 小时前
Fetch 请求竞态终结者:AbortController 不只是用来"取消"的
前端
阡陌Jony1 小时前
关于前端路由中的参数问题的学习(一): params,query, hash(#)
前端
阡陌Jony1 小时前
缓存相关学习笔记(一):Service Worker 缓存
前端