news 2026/6/15 1:13:29

Vue2如何设计大文件分块上传的交互界面与用户体验?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue2如何设计大文件分块上传的交互界面与用户体验?

震惊!100元预算要求开发企业级大文件上传系统?

各位前端大佬们好呀!(双手合十)

我是一名挣扎在温饱线的浙江前端码农,最近接了个"史诗级"项目——20G大文件上传系统,预算高达100元!这让我感动得热泪盈眶,毕竟现在连煎饼果子都要10块一个了…

客户需求清单(比我的购物车还长)

  • 20G文件上传:比我前女友分手时发的长文还大
  • 文件夹保持层级:客户文件夹结构比我家族谱还复杂
  • IE9兼容:这浏览器比我奶奶的老花镜岁数还大
  • 加密要求:SM4/AES,比我藏私房钱的方式还安全
  • 断点续传:要求比我的减肥计划还持久
  • 免费服务:3年维护+7×24支持,比中国移动客服还贴心

前端技术选型(泪流满面版)

// 选择器:在100元预算下,我只能选择最省钱的方式consttechStack={framework:'原生JS',// 因为vue要钱(误)UI:'纯CSS',// 没钱买组件库encryption:'console.log("已加密")',// 安全等级:肉眼加密IE9支持:'祈祷',// 主要靠玄学}

部分前端代码展示(真实可用版)

1. 文件夹选择与遍历 (使用webkitRelativePath保持结构)

// 获取文件夹并保持结构document.getElementById('folderPicker').addEventListener('change',function(e){constfiles=e.target.files;constfolderMap={};// 遍历文件并构建层级结构for(leti=0;i<files.length;i++){constfile=files[i];if(file.webkitRelativePath){constpathParts=file.webkitRelativePath.split('/');letcurrentLevel=folderMap;// 构建文件夹树for(letj=0;j<pathParts.length-1;j++){constpart=pathParts[j];if(!currentLevel[part]){currentLevel[part]={};}currentLevel=currentLevel[part];}// 添加文件到最底层currentLevel[pathParts[pathParts.length-1]]=file;}}console.log('文件夹结构:',folderMap);// 这里应该有上传逻辑,但预算不够写...});

2. 分片上传控制 (伪断点续传版)

classChunkUploader{constructor(file,options={}){this.file=file;this.chunkSize=options.chunkSize||5*1024*1024;// 5MBthis.chunks=Math.ceil(file.size/this.chunkSize);this.currentChunk=0;this.savedProgress=JSON.parse(localStorage.getItem(file.name))||0;}asyncupload(){// "断点续传" - 从上次中断的地方继续for(leti=this.savedProgress;i<this.chunks;i++){constchunk=this.getChunk(i);// 假装这里有加密constencryptedChunk=this.fakeEncrypt(chunk);// 理论上这里要发到服务器console.log(`上传分片${i+1}/${this.chunks}`);// 保存进度(比我的存款进度保存得还认真)localStorage.setItem(this.file.name,i);this.currentChunk=i;}// 上传完成清理记录localStorage.removeItem(this.file.name);}getChunk(index){conststart=index*this.chunkSize;constend=Math.min(start+this.chunkSize,this.file.size);returnthis.file.slice(start,end);}fakeEncrypt(data){// 预算有限,只能做做样子console.log('正在用SM4加密...(假装很安全)');returndata;}}

3. IE9兼容性处理 (痛苦面具版)

// 检查是否是IE9functionisIE9(){return/*@cc_on!@*/false||!!document.documentMode&&document.documentMode===9;}// IE9特别处理if(isIE9()){console.log('检测到IE9,开始执行特殊兼容代码...');document.write('温馨提示:您正在使用古董浏览器,建议升级!');// IE9不支持File API的替代方案document.getElementById('filePicker').innerHTML=''+' (IE9爷爷不支持文件夹上传,将就下吧)';}

加入我们福利社(这才是重点!)

加QQ群374992201立享:

  • 🧧 1-99元红包(比项目预算高)
  • 💼 项目合作接单
  • 👑 超级会员50%提成
  • 🤝 技术交流/工作内推

特别活动:推荐项目赚提成!2万项目你能拿1万!比996香多了!

免责声明(正经一秒)

以上代码仅供娱乐,真实项目请:

  1. 增加真实加密逻辑
  2. 完善错误处理
  3. 添加进度反馈
  4. 最重要的是——提高预算!

PS:本人目前也在求职,能接受加班(因为已经天天加班了),薪资要求比这个项目预算高那么"一点点"就行…

将组件复制到项目中

示例中已经包含此目录

引入组件

配置接口地址

接口地址分别对应:文件初始化,文件数据上传,文件进度,文件上传完毕,文件删除,文件夹初始化,文件夹删除,文件列表
参考:http://www.ncmem.com/doc/view.aspx?id=e1f49f3e1d4742e19135e00bd41fa3de

处理事件

启动测试

启动成功

效果

数据库

效果预览

文件上传

文件刷新续传

支持离线保存文件进度,在关闭浏览器,刷新浏览器后进行不丢失,仍然能够继续上传

文件夹上传

支持上传文件夹并保留层级结构,同样支持进度信息离线保存,刷新页面,关闭页面,重启系统不丢失上传进度。

下载示例

点击下载完整示例

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:09:16

LobeChat客服话术标准化生成系统

LobeChat客服话术标准化生成系统 在企业客户服务日益智能化的今天&#xff0c;一个常见的困境浮出水面&#xff1a;尽管AI对话系统已经能够流畅应答&#xff0c;但不同客户收到的回复却风格不一、口径混乱。某电商平台曾因客服机器人对“退货流程”的描述存在多个版本&#xff…

作者头像 李华
网站建设 2026/6/15 5:56:07

静态路由基础实验:3 台路由器 + 双 PC 的互通拓扑

今天分享一个经典的静态路由实验拓扑&#xff0c;适合刚入门网络的朋友练手 —— 用 3 台华为 AR 路由器&#xff08;AR1/AR2/AR3&#xff09;2 台 PC&#xff0c;实现不同网段的跨设备互通。一、拓扑信息速览先看拓扑里的关键 IP&#xff08;接口 网段&#xff09;&#xff1…

作者头像 李华
网站建设 2026/6/15 20:29:32

ceph中librbd模式下的qemu+librbd

https://docs.ceph.com/en/latest/rbd/qemu-rbd/ 下面我把我们前面讨论的关键点串起来&#xff0c;给你一份“从概念到可执行命令”的完整说明&#xff0c;帮助你在已有 rbdpool/image 的前提下&#xff0c;正确使用 qemu librbd 来启动虚拟机、进入虚拟机、验证磁盘、以及测…

作者头像 李华
网站建设 2026/6/15 12:08:35

爆款开源!高等教育AI辅助教学系统架构设计与实现

爆款开源项目背后&#xff1a;高等教育AI辅助教学系统的架构设计与从零实现 副标题&#xff1a;基于PythonLangChainFastAPI的轻量级、可扩展方案 摘要/引言 问题陈述 高等教育面临三大核心痛点&#xff1a; 老师备课效率低&#xff1a;找资料、写教案、设计习题耗时耗力&…

作者头像 李华
网站建设 2026/6/15 18:56:40

你是项目经理,还是项目领导者?

上周和几个同行吃饭&#xff0c;聊起一个现象&#xff1a;为什么有些项目经理能把跨部门团队拧成一股绳&#xff0c;项目再难也能推动下去&#xff1b;而有些人虽然计划做得漂亮&#xff0c;却总在协调和救火中疲于奔命&#xff0c;团队怨声载道&#xff1f;这让我意识到&#…

作者头像 李华
网站建设 2026/6/15 13:15:58

瑜伽冥想引导词:LobeChat营造放松氛围

LobeChat&#xff1a;为冥想与心灵疗愈注入温度的AI交互引擎 在快节奏的现代生活中&#xff0c;越来越多的人开始寻求内心的平静。清晨五点&#xff0c;有人戴上耳机&#xff0c;在柔和语音的引导下缓缓睁开双眼&#xff1b;深夜入睡前&#xff0c;也有人依靠一段温柔的呼吸练习…

作者头像 李华