JavaScript文件上传下载优化

分片上传通过将大文件切为2MB块并记录进度实现断点续传,结合并发控制与错误重试机制提升稳定性,使用FormData逐片上传并支持进度反馈优化体验。

文件上传下载在现代Web应用中非常常见,JavaScript可以通过多种方式优化这一过程,提升用户体验和系统性能。核心优化方向包括分片上传、断点续传、并发控制、进度反馈和资源压缩等。

分片上传与断点续传

大文件直接上传容易失败或超时,通过将文件切分为多个小块进行上传可显著提高稳定性。

实现要点:

  • 使用 File.slice() 方法将文件切片,每片一般设为1-5MB
  • 每个分片单独上传,服务端按顺序合并
  • 记录已上传分片的标识(如MD5或序号),刷新后可通过请求已上传列表实现断点续传
  • 前端本地存储(localStorage)保存上传状态,防止页面刷新丢失进度

示例代码片段:

const chunkSize = 2 * 1024 * 1024; // 2MB function uploadInChunks(file, uploadId) { let start = 0; while (start append('chunk', chunk); formData.append('uploadId', uploadId); formData.append('offset', start); fetch('/upload-chunk', { method: 'POST', body: formData }); start += chunkSize; } }

并发控制与错误重试

同时上传多个分片能加快速度,但过多请求会导致浏览器阻塞或服务器压力过大。

建议做法:

  • 限制并发请求数(如3-6个),使用队列管理待上传分片
  • 对失败的分片自动重试(最多2-3次),避免整个上传流程中断
  • 结合指数退避策略,重试间隔逐渐增加
  • 利用 Promise.allSettled 或自定义调度器控制并发流程

实时进度与用户体验

用户需要清晰知道上传/下载状态,避免误操作或焦虑等待。

关键实现:

  • 上传:监听 XMLHttpRequest.upload.onprogress 实现进度条
  • 下载:使用 压缩后再上传
  • 文本类文件(JSON、日志)可启用Gzip压缩(需服务端支持)
  • 上传前计算文件哈希(如SparkMD5),若服务端已存在相同文件则跳过上传
  • 下载时优先请求压缩版本(Accept-Encoding: gzip)

基本上就这些。合理组合分片、并发控制和压缩策略,能大幅提升文件传输效率和稳定性,尤其在弱网环境下效果明显。不复杂但容易忽略细节。