前言
大家好,这里是《前端毕业班》,前端开发者的自救互助小组。在 AI 与不确定性并存的时代,我们一起看清焦虑,聊技术、聊趋势,也聊前端还能走多远,走去哪。
郑重承诺以下内容不由 AI 生成
背景
2025年9月30号下午,uni-app社区 有开发者发布了一个帖子 https://ask.dcloud.net.cn/question/214159 ,希望能支持压缩小程序编译后的 JSON文件 以缓解包体积越来越大的问题。于是我写了一个用于压缩 JSON文件 的 unplugin 插件,可用于减小小程序端产物体积,支持 Vite、Webpack 主流构建工具。
功能特性
🗜️ 自动压缩 - 自动移除 JSON 文件中的空白字符和换行符 🔧 多构建工具支持 - 支持 Vite、Webpack、Rollup 等构建工具 ⚡ 零配置 - 开箱即用,无需额外配置 🎯 精确匹配 - 只处理 .json文件,不影响其他资源
下面是一张测试效果图,6.21KB -> 4.54KB,越大的 JSON文件 插件效果越明显。

安装
# npmnpm install @uni_toolkit/unplugin-compress-json -D# yarnyarn add @uni_toolkit/unplugin-compress-json -D# pnpmpnpm add @uni_toolkit/unplugin-compress-json -D使用方法
Vite
// vite.config.jsimport { defineConfig } from'vite'import CompressJson from'@uni_toolkit/unplugin-compress-json/vite'import uni from'@dcloudio/vite-plugin-uni'exportdefault defineConfig({ plugins: [ uni(), CompressJson(), ],})Vue CLI
// vue.config.jsconst CompressJson = require('@uni_toolkit/unplugin-compress-json/webpack')module.exports = { configureWebpack: { plugins: [ CompressJson(), ], },}工作原理
插件会在构建过程中自动检测所有 .json 文件,并移除其中的:
空格 制表符 换行符 其他空白字符
压缩前:
{"name": "example","version": "1.0.0","description": "这是一个示例"}压缩后:
{"name":"example","version":"1.0.0","description":"这是一个示例"}注意事项
插件只处理构建输出中的 .json文件不会修改源代码文件 适用于生产环境构建,可以减小打包体积
夜雨聆风