0

0

批量文件上传时,如何高效处理依赖前次上传结果的循环上传?

聖光之護

聖光之護

发布时间:2025-02-28 23:02:10

|

305人浏览过

|

来源于php中文网

原创

高效处理依赖前次上传结果的批量文件上传

本文探讨如何高效实现批量文件上传,尤其针对首个文件上传成功后,需使用其返回路径作为后续文件上传参数的场景。原始代码逻辑混乱,难以清晰处理循环上传和参数传递。

问题:upload 函数尝试上传一系列文件,核心问题在于isrepeat 参数处理和第一次上传成功路径信息的传递。foreach 循环内直接进行异步请求,难以管理请求状态和依赖关系;pathlist 参数设置逻辑不够清晰,单文件和多文件处理方式不同。

解决方案:采用异步迭代和 Promise 链式调用。以下示例演示如何使用异步函数和 Promise 处理循环上传,并根据前次上传结果决定后续操作:

笔尖Ai写作
笔尖Ai写作

AI智能写作,1000+写作模板,轻松原创,拒绝写作焦虑!一款在线Ai写作生成器

下载

批量文件上传时,如何高效处理依赖前次上传结果的循环上传?

const items = [/* 文件数组 */]; // 替换为你的文件数组
let pathList = [];

const uploadFile = async (file, isRepeat) => {
  const formData = new FormData();
  formData.append('fileList', file);
  formData.append('pathList', pathList.join(',')); // pathList 数组转字符串
  formData.append('pid', this.currentNodeKey);
  formData.append('isrepeat', isRepeat);
  // ... 其他 formData 设置 ...

  try {
    const response = await this.$myHttp({
      method: 'post',
      url: this.prefix + '/doc/docDir/uploadHtml2Public',
      data: formData,
      headers: { 'Authorization': 'Sys ' + sessionStorage.getItem('token'), 'showLoading': 'true' }
    });
    const newPath = extractPathFromResponse(response); // 自定义函数,提取路径
    pathList.push(newPath);
    return newPath;
  } catch (error) {
    console.error('上传失败:', error);
    throw error; // 抛出错误,以便后续处理
  }
};

const uploadAllFiles = async () => {
  try {
    for (const file of items) {
      const isRepeat = pathList.length > 0; // 判断是否为重复上传
      const path = await uploadFile(file, isRepeat);
      console.log(`文件上传成功,路径:${path}`);
    }
    console.log('所有文件上传完成', pathList);
  } catch (error) {
    console.error('批量上传失败', error);
    //  在此处添加错误处理逻辑,例如:提示用户上传失败,或重试上传
  }
};

uploadAllFiles();

此示例使用 async/await 更清晰地表达异步操作流程,pathlist 数组累积已上传文件的路径信息。每个文件的上传都是一个独立的 Promise,await 等待前一个 Promise 完成后再进行下一个上传。错误处理得到增强,避免单个文件上传失败导致整个上传中断。请根据实际返回的数据结构修改 extractPathFromResponse 函数。 代码使用了更简洁的 for...of 循环,提高了可读性。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

47

2025.12.04

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

536

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

22

2026.01.06

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

301

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

401

2023.10.12

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

6

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

47

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

24

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号