vue项目中如何引入zip压缩包之解决方案

最近在做项目中遇到了一个项目本地化的问题,里面有一个核心的问题是,前端需要根据后端返回的压缩包进行压缩包的解析处理。所以前端项目里需要引入这个压缩包,这个时候就遇到了很多比较坑的问题,因为项目最终是打包成一个dist目录,

所以很多方案都不行。

这是之前尝试的几种不行的方案:

方案一:发起axios请求去请求压缩包,这个方案打包后,控制台会出现axios跨域的警告问题;

方案二:使用JsZipUtils 这个插件,参考这个文章学习的,https://blog.csdn.net/weixin_44356292/article/details/108070643?spm=1001.2014.3001.5501,方案本地服务器确实可以实现,不过打包后,还是会通过发请求的方式去请求zip包,最后也会出现报跨域的错误,所以也是不行

方案三:通过webpack 插件配置,配置允许zip包引入,这种方案也行不通

方案四:通过一个webpack插件,忽略某个目录下的文件,把zip包放在一个自定义目录下,然后配置下,忽略打包自定义这个目录,结果还是不行,因为webpack打包机制的问题,只要是用import,或者require的写法引入的文件,都会被打包进去,但是博主的需求是需要动态替换这个压缩包,这就无法满足需求了

...

想了很久,最后的方案还是不行,就在这时,灵光一动,在想把zip包转成base64 字符串,通过在index.html中script标签js引入的方式来绕过webpack打包的机制,zip包也是通过字符串的方式放到js中,再动态引入,引入后,把base64转成ArrayBuffer文件流,就可以了

最后打包后,动态去替换压缩包这个js文件,index.html文件刷新后也是能展示最新的结果,这样就完成了静态目录下动态引入zip包的问题了 !

相关推荐
To_OC2 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC2 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
天渺工作室3 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny3 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi3 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒4 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__5 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒7 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569158 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔9 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js