news 2026/4/23 17:17:35

vue3+Ts实现大文件上传

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue3+Ts实现大文件上传

vue3+Ts实现大文件上传

原理
分片上传的原理就像是把一个大蛋糕切成小块一样。

首先就是将上传的大文件分成许多小块,每个小块大小相同,然后逐步上传这些小块到服务器,上传的时候,可以同时上传多个小块,也可以一个一个上传,上传每个小块之后,服务器会保存这些小块,并记录它们的顺序和位置,当我们所有的小块上传完成之后,服务器会把这些小块按照正确的顺序拼接起来,还原成我们的大文件( 下图就是基本的流程 )。

1.项目搭建
实现大文件上传

前端:vue3 + ts

2.读取文件
在我们搭建好之后,通过监听 input 的 change 事件,当提交文件之后,在回调函数中拿到对应文件。

<template><div><h1>大文件上传</h1><input type="file"@change="handleUpload"></div></template><script setup lang="ts">consthandleUpload=(e:Event)=>{// console.log((e.target as HTMLInputElement).files); // 伪数组constfiles=(e.targetasHTMLInputElement).files// 如果拿到文件返回if(!files)return//读取文件console.log(files[0]);}</script>

3.文件分片
文件分片我们会用到 Blob 对象的 slice 方法,我们在上一步获得的 File 对象,它是继承于 Blob 的。

// 1MB = 1024KB = 1024 * 1024BconstCHUNK_SIZE=1024*1024// 1MB// 在这里进行文件的分片constcreateChunks=(file:File)=>{// 设置开始的节点let cur=0// 空数组,用来存储分割后的文件块let chunks=[]// 循环遍历文件,将它分割成多个块while(cur<file.size){// 提取 start 到 end 之间的内容constblob=file.slice(cur,cur+CHUNK_SIZE)// 提取出来的内容添加到 chunks 数组中chunks.push(blob)// 更新读取的位置cur+=CHUNK_SIZE}// 返回文件块的数组returnchunks}consthandleUpload=(e:Event)=>{// console.log((e.target as HTMLInputElement).files); // 伪数组constfiles=(e.target asHTMLInputElement).files// 如果拿到文件返回if(!files)return//读取文件console.log(files[0])// 文件切片constchunks=createChunks(files[0])console.log(chunks);}

4.hash 算法
切片完成之后开始计算 hash 值,需要安装 spark-md5 工具,因为计算 hash 值需要用到。

constcalculateHash=(chunks:Blob[])=>{returnnewPromise((resolve)=>{lettarget:Blob[]=[]// 在每次计算哈希之前清空target数组// 创建一个新的SparkMD5对象,用于计算MD5哈希值constspark=newSparkMD5.ArrayBuffer();// 遍历每个Blob片段chunks.forEach((chunk,index)=>{// 如果是第一个或最后一个片段,则将其完整地加入target数组if(index===0||index===chunks.length-1){target.push(chunk);}else{// 如果是中间的片段,则只取片段的前2字节、中间2字节和最后2字节target.push(chunk.slice(0,2));target.push(chunk.slice(CHUNK_SIZE/2,CHUNK_SIZE/2+2));target.push(chunk.slice(CHUNK_SIZE-2,CHUNK_SIZE));}});// 创建一个新的FileReader对象constfileReader=newFileReader();// 读取target数组中的Blob数据为ArrayBufferfileReader.readAsArrayBuffer(newBlob(target));// 当FileReader读取完成时触发fileReader.onload=(e)=>{// 将读取的结果追加到SparkMD5对象中spark.append((e.targetasFileReader).resultasArrayBuffer);// 计算最终的MD5哈希值consthash=spark.end();// 清空target数组,避免重复使用旧数据target=[];// 解析结果resolve(hash);};});};

5.文件合并
合并需要我们前端去进行请求到后端服务器,并且传输需要的数据,然后进行操作

constmergeRequest=()=>{fetch('http://localhost:3000/merge',{method:"POST",headers:{'Content-Type':'application/json'},body:JSON.stringify({fileHash:fileHash.value,fileName:fileName.value,size:CHUNK_SIZE})}).then(()=>{alert('合并成功!')})}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:03:27

光的折射控制器

import math import tkinter as tk from tkinter import ttk, colorchooserclass RefractionVisualizer(tk.Tk):def __init__(self):super().__init__()self.title("光的折射控制器 | 斯涅尔定律可视化")self.geometry("800x600")# 初始化参数self.inciden…

作者头像 李华
网站建设 2026/4/23 6:38:14

终极指南:用CowabungaLite轻松实现iOS设备个性化定制

终极指南&#xff1a;用CowabungaLite轻松实现iOS设备个性化定制 【免费下载链接】CowabungaLite iOS 15 Customization Toolbox 项目地址: https://gitcode.com/gh_mirrors/co/CowabungaLite 想要打造独一无二的iPhone或iPad界面&#xff0c;但又不想冒险越狱&#xff…

作者头像 李华
网站建设 2026/4/23 6:39:24

SOCD清洁器终极指南:让键盘操作如丝般顺滑的免费神器

在竞技游戏的激烈对抗中&#xff0c;你是否曾经因为同时按下左右方向键而原地罚站&#xff1f;或者在连招时因为方向冲突导致必杀技变成普通攻击&#xff1f;今天我要向你推荐一款让职业玩家都爱不释手的开源工具——SOCD清洁器&#xff0c;它能彻底解决这些让你抓狂的操作问题…

作者头像 李华
网站建设 2026/4/23 8:05:21

Windows驱动管理终极方案:DriverStore Explorer全面使用手册

Windows驱动管理终极方案&#xff1a;DriverStore Explorer全面使用手册 【免费下载链接】DriverStoreExplorer Driver Store Explorer [RAPR] 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 还在为Windows系统驱动问题烦恼吗&#xff1f;DriverSto…

作者头像 李华
网站建设 2026/4/23 6:37:57

终极解决方案:Zotero插件市场如何彻底改变你的文献管理效率

终极解决方案&#xff1a;Zotero插件市场如何彻底改变你的文献管理效率 【免费下载链接】zotero-addons Zotero add-on to list and install add-ons in Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-addons 还在为海量PDF文献的整理而烦恼吗&#xff1f…

作者头像 李华
网站建设 2026/4/23 6:39:25

BabelDOC终极指南:零基础掌握PDF文档智能翻译与双语生成

BabelDOC终极指南&#xff1a;零基础掌握PDF文档智能翻译与双语生成 【免费下载链接】BabelDOC Yet Another Document Translator 项目地址: https://gitcode.com/GitHub_Trending/ba/BabelDOC 在当今全球化的数字时代&#xff0c;PDF文档的跨语言交流需求日益增长。Bab…

作者头像 李华