vue3+vite打包自动生成dist.zip压缩包(输出后的包名可改变)

先写个生成zip的功能。新建一个zip.js文件,放在和vite.config.js同一级,需先安装插件jszip:npm i jszip -D :

//  zip.js 打包自动生成zip包,需npm i jszip -D
const plugin = function(fileName = 'equipMonitorDist', output){
    const path = require('path');            
    if(!output)output = path.resolve(__dirname,'./equipMonitorDist');//./distTest是根据实际路径而来
    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)
        const readDir = function (zip, 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 = zip.folder(fileName);
                    readDir(dirZip, fillPath);
                } else {
                    // 读取每个文件为buffer存到zip中
                    zip.file(fileName, fs.readFileSync(fillPath))
                }
            });
        }
        const removeExistedZip = () => {
            const dest = path.join(distPath, './' + fileName)
            if (fs.existsSync(dest)) {
                fs.unlinkSync(dest)
            }
        }
        const zipDir = function () {
            readDir(zip, 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.js中引入插件,也可安装文件压缩插件npm i vite-plugin-compression -D:

//  vite.config.js
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from "path";
import myPlugin from './zip'
import viteCompression from 'vite-plugin-compression';
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
    vue(),
    myPlugin(),
    viteCompression({
      threshold: 1024 * 500, // 对大于500kb的文件进行压缩
      algorithm: 'gzip', // 采用的压缩算法,默认是 gzip
      ext: '.gz', // 生成的压缩包后缀
    }),
  ],
  resolve: {
    alias: {
      "@": path.resolve(__dirname, "src"),
    },
  },
  build: {
      sourcemap: false,
      outDir: 'equipMonitorDist',
      rollupOptions: {
        output: {
          chunkFileNames: 'assets/js/[name]-[hash].js',
          entryFileNames: 'assets/jsEntry/[name]-[hash].js', //html引入的js文件
          assetFileNames: 'assets/[ext]/[name]-[hash].[ext]',
        },
        brotliSize: true, // 不统计
        target: 'esnext',
        minify: 'esbuild', // 混淆器,terser构建后文件体积更小
      },
    },
})

打包成功之后效果如下:

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
当你使用vue3和vite进行打包后,如果在服务器上打开页面时出现空白的情况,这可能是由于文件路径引发的404错误导致的。 初步分析,可能是你的打包文件中的资源文件(例如js和css文件)的引用路径不正确,导致服务器无法找到这些文件而出现404错误。 解决这个问题的方法之一是检查你的打包配置,确保资源文件的引用路径是正确的。你可以尝试修改vite的配置文件,特别是关于打包路径的配置,确保所有的资源文件都能被正确地加载。另外,还可以检查你的index.html文件,确保引用的资源文件路径与打包后的文件路径一致。 此外,还有一种可能是你的打包文件中存在其他问题,例如代码错误或依赖缺失,导致页面无法正确渲染。你可以使用浏览器的开发者工具控制台,查看是否有其他报错信息,以便更好地定位问题。 如果问题仍然存在,建议你查看具体的错误信息、文件路径以及打包配置,以便更好地分析和解决问题。如果需要进一步帮助,请提供更多详细的信息,例如打包配置和错误信息,以便我们更好地帮助你解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue3用vite打包上服务器后报错显示页面空白](https://blog.csdn.net/k490031/article/details/129733118)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [“Vue3+Vite打包后,白屏沉默,重启重试无果,我该如何解决?”](https://blog.csdn.net/weixin_44637104/article/details/131342307)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [浏览器显示数据库中数据的条形图柱状图 前后端分离vue.js+spring boot 计算机软件工程课程设计毕业设计 ...](https://download.csdn.net/download/Amzmks/88275824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值