vite打包后自动将dist文件夹压缩

压缩文件用到的插件是jszip

先写个生成zip的功能。新建一个zip.js文件

//  zip.js
const plugin = function (fileName = 'product2_web', output) {
	const path = require('path')
	if (!output) output = path.resolve(__dirname, '../dist')
	fileName += '.zip'
	const makeZip = function () {
		const path = require('path')
		const fs = require('fs')
		const JSZip = require('jszip')
		const zip = new JSZip()
		const distPath = path.resolve(output)
		// 因为我想压缩包中的dist文件夹层级保留 且重新命名为product2_web 所以这里设置了allFolder  ,如果不要该层级 则直接用zip即可
		let allFolder = zip.folder('product2_web')
		const readDir = function (allFolder, dirPath) {
			// 读取dist下的根文件目录
			const files = fs.readdirSync(dirPath)
			files.forEach((fileName) => {
				const fillPath = path.join(dirPath, './', fileName)
				const file = fs.statSync(fillPath)
				// 如果是文件夹的话需要递归遍历下面的子文件
				if (file.isDirectory()) {
					const dirZip = allFolder.folder(fileName)
					readDir(dirZip, fillPath)
				} else {
					// 读取每个文件为buffer存到zip中
					allFolder.file(fileName, fs.readFileSync(fillPath))
				}
			})
		}
		const removeExistedZip = () => {
			const dest = path.join(distPath, './' + fileName)
			if (fs.existsSync(dest)) {
				fs.unlinkSync(dest)
			}
		}
		const zipDir = function () {
			readDir(allFolder, distPath)
			zip.generateAsync({
				type: 'nodebuffer', // 压缩类型
				compression: 'DEFLATE', // 压缩算法
				compressionOptions: {
					// 压缩级别
					level: 9
				}
			}).then((content) => {
				const dest = path.join(distPath, '../' + fileName)
				removeExistedZip()
				// 把zip包写到硬盘中,这个content现在是一段buffer
				fs.writeFileSync(dest, content)
			})
		}
		removeExistedZip()
		zipDir(distPath)
	}
	return {
		name: 'vite-plugin-auto-zip',
		apply: 'build',
		closeBundle() {
			makeZip()
		}
	}
}
module.exports = plugin

然后在vite.config.ts中配置即可

import myPlugin from './script/zip'
plugins: [
			vue(),
			myPlugin()
		]

打包后就会自动生成product2_web的压缩包

 

 

可配置打包后自动提交git

 

当你在使用 Electron 和 Vite 构建项目并尝试打包,可能会遇到“文件路径找不到”的错误。这通常是由于配置不当、资源引用错误或构建后的目录结构不符合预期导致的问题。 以下是几个常见的原因及解决方案: --- ### 原因分析 #### 1. **主进程和渲染进程之间的相对路径问题** 如果你在主进程中通过 `__dirname` 或其他方式访问静态资源(例如图片、数据库等),但未考虑到最终打包后的实际路径位置,就会导致找不到指定的文件。 **解决方法:** - 确保你始终从项目的根目录开始查找文件。 - 使用 `path.join(__dirname, './yourFile')` 来动态拼接正确的绝对路径。 #### 2. **Vite 的 assets 目录设置** Vite 默认会将静态资源放在打包生成的 `/dist/assets/` 文件夹下。如果你直接引用了某些资源而未更新其路径,则可能导致运行无法找到对应的文件。 **解决方法:** - 检查 `vite.config.js` 中是否设置了 `build.assetsDir` 配置项,默认值为 `'assets'`。 - 打包完成后检查生成的目标目录 (`dist`) 下是否有对应文件存在,并调整前端代码中的资源路径指向。 #### 3. **Electron Builder 配置** 当使用工具如 electron-builder 进行应用分发,它会对整个程序进行压缩封装成asar归档文件形式存放内容物;如果忘记修改默认规则使得部分自定义依赖没被打进去的话同样会出现缺失的情况。 **解决办法:** - 修改 `electron-builder.json` 或者 `.erb/config/build.config.js` ,添加需要包含进来的额外非npm模块到 `"files"` 数组里去; ```json { "directories": { "output": "release" }, "files":[ //此处补充所有需要用到的东西 "**/*", "!node_modules/**" ] } ``` 此外也可以明确指出哪些特殊类型的二进制大体积数据应该单独存于解压区而非合并至ASAR内部: ```js extraResources:[ { from:'./data',to:'appData'} ] ``` 然后就可以放心地按照原始地址加载本地存储的数据啦! --- ### 总结步骤排查流程 1. 核对源码内涉及的所有外部素材链接字符串是否准确无误; 2. 查阅官方文档了解各个框架插件的工作原理再结合自身需求定制适合自己的方案; 3. 最后别忘了每次更改完重要设定之后都要清理旧缓存重新编译一遍测试效果哦~ 希望以上信息对你有所帮助!如果有更详细的具体报错消息或者其他关联疑问欢迎继续提问~ ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值