FormData详解

一、formdata传数组对象

在前端开发过程中,有时我们需要上传的数据是一个数组对象,这时候我们可以使用FormData将数组对象传给后台。

举个例子:

let arr = [{name:'张三', age:20},{name:'李四', age:21},{name:'王五', age:22}];

首先,我们需要将数组对象转成JSON字符串格式,然后再通过FormData传给后台:

let formData = new FormData();
formData.append('data', JSON.stringify(arr));

在后台可以通过如下代码来解析数组对象:

let data = JSON.parse(req.body.data);
console.log(data);
// [{name:'张三', age:20},{name:'李四', age:21},{name:'王五', age:22}]

二、微信小程序使用FormData

在微信小程序中,可以使用wx.uploadFile方法上传文件,该方法支持FormData对象。

举个例子:

wx.chooseImage({
  success: function (res) {
    var tempFilePaths = res.tempFilePaths
    wx.uploadFile({
      url: 'https://example.com/upload', //仅为示例,非真实的接口地址
      filePath: tempFilePaths[0],
      name: 'file',
      formData:{
        'user': 'test'
      },
      success: function (res){
        var data = res.data
        //do something
      }
    })
  }
})

我们可以通过wx.uploadFile方法上传文件,并且发送FormData数据。

三、FormData转换成JSON

有时候我们需要将FormData对象转成JSON字符串格式,可以通过以下代码实现:

let formData = new FormData(document.querySelector('form'));
let jsonObj = {};
for (let [key,value] of formData.entries()) {
  jsonObj[key] = value;
}
let jsonString = JSON.stringify(jsonObj);

这样就可以将FormData对象转换成JSON格式。

四、如何把FormData中的文件解析出来

FormData中的文件需要通过后台接口来解析,前端可以通过FormData对象的get方法来获取文件:

let formData = new FormData(document.forms[0]);
let file = formData.get('file');
console.log(file);

五、FormData.append怎么用

FormData.append方法可以向FormData对象中添加一个键值对,如下所示:

let formData = new FormData();
formData.append('name', '张三');
formData.append('age', '20');

六、FormData和JSON区别

FormData主要用于序列化表单以及创建表单数据,可以通过ajax提交表单数据。而JSON数据格式是一种比较流行的数据交换格式,可以用于前后端数据交换、存储等。FormData主要用于传输表单数据,而JSON可以用于存储/交换任何类型的数据。

七、文件流如何放进FormData

我们可以通过Blob对象来将文件流放进FormData对象中:

let blob = new Blob(['Hello, world!'], { type: 'text/plain' });
let formData = new FormData();
formData.append('file', blob);

八、FormData格式

FormData的格式类似于键值对的格式,如下所示:

let formData = new FormData();
formData.append('name', '张三');
formData.append('age', '20');

九、FormData参数

FormData有以下参数:

  • append(name, value, filename): 向FormData对象添加一个键值对
  • delete(name): 删除FormData对象中指定键名的键值对
  • get(name): 返回指定键名对应的值
  • getAll(name): 返回指定键名对应的所有值
  • set(name, value, filename): 修改FormData对象中指定键名对应的值
  • has(name): 判断FormData对象中是否存在指定键名的键值对
  • entries(): 返回FormData对象中所有的键值对

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/241814.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 12:43
下一篇 2024-12-12 12:44

相关推荐

  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25

发表回复

登录后才能评论