news 2026/6/10 19:28:19

使用vue-cli如何实现内网超大附件的文件夹上传?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用vue-cli如何实现内网超大附件的文件夹上传?

《一个预算100元的前端老哥自白》

各位老铁好啊!我是一名甘肃前端老兵,最近接了个"惊天地泣鬼神"的外包需求,100元预算要搞出价值10万的项目功能,这波操作简直比用算盘开发AI还刺激!

一、需求理解:100元买劳斯莱斯

客户想要的功能清单:

  • 20G文件上传:我家路由器看到这需求直接自闭了
  • IE9兼容:这要求比我爷爷的老年机跑《原神》还难
  • 保留文件夹结构:1000个文件的目录树,我家族谱都没这么复杂
  • 断点续传:关了浏览器还得记住进度,这功能该叫"程序员记忆面包"
  • 加密传输:SM4+AES双加密,我支付宝都没这待遇
  • 3年免费维护:100元买我三年青春?

二、技术方案:用情怀发电

核心代码展示(IE9特别魔改版)

// 文件夹上传处理(高血压警告)functionhandleFolderUpload(event){// IE9特殊处理if(navigator.userAgent.indexOf('MSIE 9')>-1){alert('检测到史前浏览器,建议升级到21世纪');returnPromise.reject('建议客户把这台电脑送进博物馆');}constfiles=event.target.files;constfolderPromises=[];// 递归处理文件夹functionprocessEntry(entry,path=''){returnnewPromise((resolve)=>{if(entry.isFile){entry.file(file=>{// 假装这里有很多处理代码console.log(`处理文件:${path}/${file.name}`);resolve();});}elseif(entry.isDirectory){constdirReader=entry.createReader();dirReader.readEntries(entries=>{constpromises=entries.map(childEntry=>processEntry(childEntry,`${path}/${entry.name}`));Promise.all(promises).then(resolve);});}});}// 遍历文件项for(leti=0;i<files.length;i++){constentry=files[i].webkitGetAsEntry();if(entry){folderPromises.push(processEntry(entry));}}returnPromise.all(folderPromises).then(()=>alert('文件夹上传成功(也许)')).catch(err=>console.error('上传失败:',err));}

文件分片上传(梦想版)

// 文件分片处理(伪代码)functionuploadFileInChunks(file){constCHUNK_SIZE=5*1024*1024;// 5MBconstchunks=Math.ceil(file.size/CHUNK_SIZE);letuploaded=0;// 检查本地存储的进度constsavedProgress=localStorage.getItem(`upload_${file.name}`);if(savedProgress){uploaded=parseInt(savedProgress);console.log(`从上次中断的第${uploaded}块继续`);}functionuploadChunk(chunkNum){conststart=chunkNum*CHUNK_SIZE;constend=Math.min(file.size,start+CHUNK_SIZE);constchunk=file.slice(start,end);// 这里应该是AJAX请求console.log(`上传第${chunkNum+1}/${chunks}`);// 模拟上传延迟setTimeout(()=>{localStorage.setItem(`upload_${file.name}`,chunkNum+1);if(chunkNum<chunks-1){uploadChunk(chunkNum+1);}else{console.log('上传完成!');localStorage.removeItem(`upload_${file.name}`);}},500);}uploadChunk(uploaded);}

加密传输(玄学版)

// 假装这是SM4加密(实际请使用正规库)functionfakeSM4Encrypt(data){console.warn('预算不足,使用灵魂加密法');returnbtoa(unescape(encodeURIComponent(data))).split('').reverse().join('')+'==';}

三、IE9兼容方案(劝退版)

四、实用建议

  1. 关于预算:100元连VSCode主题都买不起,建议报价加两个零
  2. 关于IE9:直接告诉客户兼容IE9的代价是买新电脑的10倍
  3. 关于20G文件:先问问客户服务器硬盘是不是用天河一号
  4. 关于3年维护:建议改成"3天内可以发微信咨询"

五、文件夹结构保持技巧

// 文件树结构示例constfileTree={name:'root',type:'directory',children:[{name:'documents',type:'directory',children:[{name:'resume.doc',type:'file',size:1024},{name:'photo.jpg',type:'file',size:2048}]},{name:'README.txt',type:'file',size:512}]};

六、QQ群真相调查

“加群送红包”:进群后发现红包是0.01元分100份
“50%提成”:原来是项目亏损的50%
“比打工强”:确实,毕竟打工还发工资呢

七、生存指南

  1. 需求评审:把"支持IE9"改成"额外收费项目"
  2. 进度管理:告诉客户100元只够写README文件
  3. 技术选型:多用console.log调试(毕竟debugger要加钱)
  4. 职业规划:已经开始看美团骑手招募广告

最后的呐喊

老哥们!那个QQ群广告才是重点对吧?这波拉人头的操作比你的前端代码6多了!(战术后仰)

将组件复制到项目中

示例中已经包含此目录

引入组件

配置接口地址

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

处理事件

启动测试

启动成功

效果

数据库

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

下载示例

点击下载完整示例

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

电力市场节点边际电价出清全时段分析:有无阻塞情况

电力市场节点边际电价出清全时段 有无阻塞情况分析 完美复现文献《机组运行约束对节点电价的影响分析》史新红 程序考虑爬坡约束&#xff0c;上下备用约束&#xff0c;注释清晰 适合电力市场初学者 仿真平台&#xff1a;基于matlabyalmipcplex 附赠5节点系统excel数据节点电价…

作者头像 李华
网站建设 2026/6/9 22:47:44

2026 年智能写作 AI 论文生成软件权威榜单

核心速览&#xff1a;PaperRed与毕业之家 AI稳居全流程全能型榜首&#xff0c;DeepSeek领跑理工科&#xff0c;ChatGPTScholarGPT是国际学术标杆。以下按综合排名与分类榜单双维度呈现&#xff0c;附核心功能、评分、优势与适用场景&#xff0c;助你精准选型。 一、综合 TOP8 …

作者头像 李华
网站建设 2026/6/6 0:52:37

档案长期安全存储的国产方案信刻全自动蓝光光盘库

档案作为“记录历史、传承文明、服务社会”的重要载体&#xff0c;属于不可再生的宝贵资源&#xff0c;故而&#xff0c;筑牢档案安全防线&#xff0c;维护档案的完整与安全是档案管理工作的核心要求。近年来&#xff0c;《档案法实施条例》、《电子档案管理办法》等政策法规的…

作者头像 李华
网站建设 2026/6/10 13:10:36

创作的第256天:当技术博客成为我的第二份“原理图”

目录 一、起点&#xff1a;为什么是阻抗匹配&#xff1f; 二、256天的“硬件设计”&#xff1a;我的知识拓扑图 三、技术之外的发现&#xff1a;博客作为“调试工具” 四、那些数字背后的温度 五、持续创作的“电源管理” 六、未来的“原理图升级” 结语&#xff1a;创作…

作者头像 李华
网站建设 2026/6/10 13:08:51

vue-office:5.4k 预览组件库,支持 docx/xlsx/pdf/pptx

Java精选面试题&#xff08;微信小程序&#xff09;&#xff1a;5000道面试题和选择题&#xff0c;包含Java基础、并发、JVM、线程、MQ系列、Redis、Spring系列、Elasticsearch、Docker、K8s、Flink、Spark、架构设计、大厂真题等&#xff0c;在线随时刷题&#xff01;一、项目…

作者头像 李华