将传给后端的数据转换为以formData的类型传递

javascript 复制代码
export function tranFormData(params) {
    console.log('tranFormData---------------', params);

    // 检查输入是否已经是 FormData,如果是,则直接返回
    if (params instanceof FormData) {
        return params;
    }

    const formData = new FormData();

    /**
     * 递归函数,用于将数据添加到 FormData 中
     * @param {string} key - 当前处理的数据的键
     * @param {*} value - 当前处理的数据的值
     */
    const appendToFormData = (key, value) => {
        // 如果值是文件或 Blob 对象的数组,则直接追加
        if (
            Array.isArray(value) &&
            value.some(
                (file) =>
                (file instanceof File) || (file instanceof Blob)
            )
        ) {
            value.forEach((file) => {
                formData.append(key, file);
            });
            return;
        }

        // 如果值是数组,则递归处理数组中的每个元素
        if (Array.isArray(value)) {
            if (value.length === 0) {
                formData.append(`${key}[]`, ''); // 处理空数组的情况
            } else {
                value.forEach((item, index) => {
                    // 递归调用,处理数组中的每个元素
                    appendToFormData(`${key}[${index}]`, item);
                });
            }
            return;
        }

        // 如果值是对象(但不是 File 或 Blob),则递归处理对象中的每个键值对
        if (typeof value === 'object' && value !== null && !(value instanceof File) && !(value instanceof Blob)) {
            Object.keys(value).forEach((objKey) => {
                if (value[objKey] !== null) {
                    // 递归调用,处理对象中的每个属性
                    appendToFormData(`${key}.${objKey}`, value[objKey]);
                }
            });
            return;
        }

        // 对于所有其他基本类型(字符串、数字、布尔值)以及 File 和 Blob 对象,直接追加
        if (value !== null) {
            formData.append(key, value);
        }
    };

    // 遍历初始参数对象的每个键,并开始递归处理
    Object.keys(params).forEach((key) => {
        appendToFormData(key, params[key]);
    });

    return formData;
}
相关推荐
Wenweno0o14 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
于慨14 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz14 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶14 小时前
前端交互规范(Web 端)
前端
@yanyu66614 小时前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU72903514 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
chenjingming66614 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
GISer_Jing14 小时前
Page-agent MCP结构
前端·人工智能
王霸天14 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航14 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github