告别浏览器卡顿:大型文件上传的流式传输优化方案
上传大型文件时,传统的XHR方法常常导致浏览器卡顿和内存占用过高。本文介绍如何利用流式传输技术优化大型文件上传,提升用户体验。
优化策略:实时传输,避免缓存
通过Fetch API获取响应流,并在下载的同时将数据直接写入目标服务器的上传请求流中。此方法避免了在浏览器端缓存整个文件,从而有效降低内存消耗,防止浏览器卡顿。
代码示例
以下代码片段演示了如何使用Fetch API实现流式文件上传:
fetch('/file.zip').then((resp) => { fetch('/upload', { body: resp.body, method: 'POST', duplex: 'half' }); });
兼容性及限制
需要注意以下几点:
- Safari浏览器不支持请求流。
- HTTP协议版本低于2.0不支持请求流功能。
更多技术细节,请参考Chrome开发者文档:https://www.php.cn/link/7df2a3f0d266869c59413708e4acdb01 (此处需替换为实际文档链接)