将传给后端的数据转换为以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;
}
相关推荐
傻乐u兔3 小时前
C语言进阶————指针4
c语言·开发语言
大模型玩家七七3 小时前
基于语义切分 vs 基于结构切分的实际差异
java·开发语言·数据库·安全·batch
历程里程碑3 小时前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法
恋猫de小郭3 小时前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
牛奔4 小时前
Go 如何避免频繁抢占?
开发语言·后端·golang
寻星探路8 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
崔庆才丨静觅10 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
lly20240610 小时前
Bootstrap 警告框
开发语言
2601_9491465311 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
曹牧11 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言