将传给后端的数据转换为以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;
}
相关推荐
奔跑的呱呱牛1 分钟前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
于先生吖2 分钟前
Java框架开发短剧漫剧系统:后台管理与接口开发
java·开发语言
柳杉17 分钟前
从动漫水面到赛博飞船:这位开发者的Three.js作品太惊艳了
前端·javascript·数据可视化
khddvbe18 分钟前
C++并发编程中的死锁避免
开发语言·c++·算法
Greg_Zhong40 分钟前
前端基础知识实践总结,每日更新一点...
前端·前端基础·每日学习归类
We་ct1 小时前
LeetCode 148. 排序链表:归并排序详解
前端·数据结构·算法·leetcode·链表·typescript·排序算法
wWYy.1 小时前
STL:list
开发语言·c++
TON_G-T1 小时前
day.js和 Moment.js
开发语言·javascript·ecmascript
飞Link1 小时前
具身智能核心架构之 Python 行为树 (py_trees) 深度剖析与实战
开发语言·人工智能·python·架构