news 2026/5/15 23:53:35

使用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/5/13 20:38:37

芯片制造企业文档系统怎样处理Origin数据图到网页的粘贴?

今天早上&#xff0c;又有技术爱好者通过公开渠道找到我的联系方式并加我微信&#xff0c;表示对我们正在探索的Word文档导入编辑器技术感兴趣&#xff0c;想了解具体方案。其实&#xff0c;我的联系方式之前已在多个平台公开&#xff0c;但仍有不少朋友反馈难以找到&#xff0…

作者头像 李华
网站建设 2026/5/13 9:07:07

分布式电源接入对配电网的影响——基于Matlab程序的潮流计算与分析

分布式电源接入对配电网的影响&#xff08;matlab程序&#xff09; 分布式电源的接入使得配电系统从放射状无源网络变为分布有中小型电源的有源网络。 带来了使单向流动的电流方向具有了不确定性等等问题&#xff0c;使得配电系统的控制和管理变得更加复杂。 但同时&#xff0c…

作者头像 李华
网站建设 2026/5/13 20:37:51

多用户小程序源码系统,核心功能齐全,助力您快速部署创业

温馨提示&#xff1a;文末有资源获取方式 市场上通用的SaaS模板往往无法完全契合每家洗衣店独特的业务模式和运营构想。对于追求自主控制、期望功能独具特色的商家或开发者而言&#xff0c;一套开源、可深度定制的源码才是真正的宝藏。本文将以列表形式&#xff0c;解析一款高度…

作者头像 李华
网站建设 2026/5/13 20:39:02

Java 面向对象进阶三

第一章 接口1.1 概述我们已经学完了抽象类&#xff0c;抽象类中可以用抽象方法&#xff0c;也可以有普通方法&#xff0c;构造方法&#xff0c;成员变量等。那么什么是接口呢&#xff1f;接口是更加彻底的抽象&#xff0c;JDK7之前&#xff0c;包括JDK7&#xff0c;接口中全部是…

作者头像 李华
网站建设 2026/5/12 14:32:54

智能守护:视频安全监测系统的演进与未来

在城市天际线与街巷角落&#xff0c;数以亿计的摄像头正悄然编织一张无形的安全网络。然而&#xff0c;当监控画面从“被动记录”迈向“主动预警”&#xff0c;视频安全监测系统已不再是简单的录像工具&#xff0c;而是融合人工智能、边缘计算与大数据的智能守护者。一、超越“…

作者头像 李华
网站建设 2026/5/15 15:12:37

全网最全9个降AI率网站推荐!千笔·降AIGC助手帮你精准降AIGC

AI降重工具如何精准降低AIGC率&#xff1f; 在当前学术写作和论文提交中&#xff0c;AI生成内容的痕迹越来越明显&#xff0c;很多学生和研究人员都面临“论文被查出高AIGC率”的困扰。为了确保论文通过检测系统&#xff0c;越来越多的人开始依赖专业的AI降重工具。这些工具不仅…

作者头像 李华