前端传递参数时form-data和json的区别详解

 更新时间:2023年11月07日 08:27:03   作者:一嘴一个橘子  
前端可以通FormData对象实现表单形式提交数据,下面这篇文章主要给大家介绍了关于前端传递参数时form-data和json区别的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

在传递参数时,form-data 和 JSON 是两种常见的数据格式。

  • form-data 是一种多部分表单数据格式,通常用于上传文件或包含二进制数据的表单提交。它使用 multipart/form-data 格式来编码数据。在使用 form-data 格式时,数据会被分割成多个部分,每个部分都有自己的头部信息。

  • JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于前后端数据传输。它使用键值对的形式来表示数据,并且支持嵌套结构。JSON 数据格式是纯文本的,易于阅读和编写,同时也易于解析和生成。

生成 form-data 格式的数据通常需要使用 FormData 对象来处理,示例代码如下:

const formData = new FormData();
formData.append('username', 'John');
formData.append('avatar', file); // 上传文件

// 发送请求
axios.post('/api/endpoint', formData, {
  headers: {
    'Content-Type': 'multipart/form-data'
  }
});

生成 JSON 格式的数据可以通过创建一个包含键值对的 JavaScript 对象,并使用 JSON.stringify 方法将其转换为字符串,示例代码如下:

const data = {
  username: 'John',
  age: 25
};

// 发送请求
axios.post('/api/endpoint', JSON.stringify(data), {
  headers: {
    'Content-Type': 'application/json'
  }
});

在示例中,axios 是一个常用的 HTTP 请求库,用于发送请求。headers 部分用于设置请求头,确保服务器能够正确解析请求数据的格式。

需要根据具体的需求和后端接口的要求选择使用 form-data 还是 JSON 格式的数据传递。

附:form-data 转json

form-data转json的方法可以使用JavaScript中的FormData对象和serializeArray()方法来实现。首先,我们可以使用FormData对象来获取表单中的所有数据,然后使用serializeArray()方法将FormData对象转换为一个包含键值对的数组。接下来,我们可以遍历这个数组,将每个键值对转换为一个JSON对象。在转换过程中,我们可以根据需要对值进行自定义处理,比如将空值转换为null。最后,将所有的JSON对象组合成一个对象数组并返回。

以下是一个示例代码,用于将form-data转换为JSON对象数组:

function transformToJson(form) {
  var jsonData = {};
  var formData = new FormData(form);
  var formArray = $(form).serializeArray();

  $.each(formArray, function() {
    var dataType = $("select\[name='" + this.name + "'\]").attr("data-type");
    var value = this.value;

    if (value == "无" || value == "") {
      value = null;
    }

    if (jsonData\[this.name\]) {
      if (!jsonData\[this.name\].push) {
        jsonData\[this.name\] = \[jsonData\[this.name\]\];
      }
      jsonData\[this.name\].push(value || '');
    } else {
      if (dataType == 'array') {
        jsonData\[this.name\] = \[\];
        jsonData\[this.name\].push(value || '');
      } else {
        jsonData\[this.name\] = value || '';
      }
    }
  });

  return jsonData;
}

这个函数接受一个表单作为参数,并返回一个转换后的JSON对象数组。你可以将表单元素传递给这个函数,然后使用返回的JSON对象数组进行后续操作。

总结

到此这篇关于前端传递参数时form-data和json区别的文章就介绍到这了,更多相关前端传递参数form-data和json区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论