首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

vuejs FormData不发送json

Vue.js FormData不发送 JSON 是指在使用 Vue.js 框架中的 FormData 对象时,无法直接将数据以 JSON 格式发送到服务器。

FormData 是一种用于创建表单数据的对象,常用于通过 AJAX 请求将表单数据发送到服务器。它可以模拟表单提交,支持文件上传和多部分编码。然而,FormData 对象默认以 multipart/form-data 格式发送数据,而不是以 JSON 格式发送。

要发送 JSON 数据,可以使用 Vue.js 的 axios 库或其他 AJAX 库将数据转换为 JSON 格式,并设置请求头的 Content-Type 为 application/json。以下是一个示例:

代码语言:javascript
复制
import axios from 'axios';

// 创建一个 FormData 对象
const formData = new FormData();
formData.append('name', 'John');
formData.append('age', 25);

// 将 FormData 转换为 JSON 格式
const jsonData = {};
formData.forEach((value, key) => {
  jsonData[key] = value;
});

// 发送 JSON 数据
axios.post('/api/data', jsonData, {
  headers: {
    'Content-Type': 'application/json'
  }
})
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.error(error);
  });

在上述示例中,我们首先创建一个 FormData 对象,并向其添加表单数据。然后,我们通过遍历 FormData 对象的键值对,将其转换为 JSON 格式。最后,使用 axios 发送 POST 请求,并设置请求头的 Content-Type 为 application/json。

关于 Vue.js、axios 和 FormData 的更多信息,可以参考以下链接:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

.Net之使用Jquery Ajax通过FormData对象异步提交图片文件到服务端保存并返回保存的图片路径

首先对于图片上传而言,在我们的项目开发中可以说出现的频率是相当的高的。这篇文章中,我将要描述的是在我们.Net中如何使用Jquery Ajax通过FormData对象异步提交图片文件到后台保存,并返回保存的图片路径展示出图片,实现一个无刷新的异步图片上传的过程,当然这里我讲解的是单张图片的保存过程,对于多图片上传的话其实我们只需要在type='file'文本框中加上一个multiple可多选,然后获取input中的文件数组遍历向后台提交感兴趣的话可以尝试,不过下一篇博客将会讲解如何使用Layui上传多张图片到服务端保存。

02

一文了解文件上传全过程(项目中碰到的难点)

平常在写业务的时候常常会用的到的是 GET, POST请求去请求接口,GET 相关的接口会比较容易基本不会出错,而对于 POST中常用的 表单提交,JSON提交也比较容易,但是对于文件上传呢?大家可能对这个步骤会比较害怕,因为可能大家对它并不是怎么熟悉,而浏览器Network对它也没有详细的进行记录,因此它成为了我们心中的一根刺,我们老是无法确定,关于文件上传到底是我写的有问题呢?还是后端有问题,当然,我们一般都比较谦虚, 总是会在自己身上找原因,可是往往实事呢?可能就出在后端身上,可能是他接受写的有问题,导致你换了各种请求库去尝试,axios,request,fetch 等等。那么我们如何避免这种情况呢?我们自身要对这一块够熟悉,才能不以猜的方式去写代码。如果你觉得我以上说的你有同感,那么你阅读完这篇文章你将收获自信,你将不会质疑自己,不会以猜的方式去写代码。

02
领券