




根本原因在于模块加载机制不同:Webpack 启动前需打包整个依赖图,Vite 利用浏览器原生 ESM 按需编译单文件,启动快 10–100 倍;Vite 轻量 HTTP 服务+esbuild 转换,Webpack 则需完整构建流程。
根本原因在于模块加载机制不同:Webpack 启动前必须先打包整个依赖图,而 Vite 利用浏览器原生 ESM,在请求时才按需编译单个 .vue 或 .ts 文件。
dev-server 启动耗时 = 依赖分析 + AST 解析 + 模块转换 + 打包生成内存 bundle,项目越大越慢dev server 启动几乎不扫描源码,只起一个轻量 HTTP 服务,首次页面访问才触发对应文件的 esbuild 转换(快 10–100 倍)import,IE11 等旧环境无法直接运行,Webpack 仍需承担兼容兜底职责vite.config.ts 和 webpack.config.js 的核心差异点不是“写法像不像”,而是“配置目标是否同构”:Vite 配置聚焦 dev 体验与构建输出控制;Webpack 配置则需同时兼顾开发、测试、构建、SSR 等多阶段行为。
resolve.alias 默认已包含 @ → src/,无需手动设;Webpack 必须显式写 resolve: { alias: { '@': path.resolve(__dirname, 'src') } }
build.rollupOptions 是透传给底层 Rollup 的,不能直接写 plugins: [myPlugin()] 就生效——得确认该插件是否兼容 Rollup 3+ 和 Vite 生命周期module.rules 是硬编码匹配逻辑(如 /\.css$/),Vite 的 CSS 处理由内置插件接管,加 css.preprocessor 即可切 scss/less,无需 loader 配置Webpack 更透明,Vite 更省心但黑盒略多。两者都用 Rollup 打包,但 Vite 把很多优化开关封装掉了。
splitChunks.chunks、minimizer、optimization.realContentHash 等,适合对 CDN 缓存、长期有效性有强要求的场景build.sourcemap: false,且不暴露 Terser 配置入口;想改压缩参数得通过 build.minify: 'terser' + build.terserOptions,不如 Webpack 直观build.lib 模式适合打包 UI 组件库,会自动处理 exports 和 types,Webpack 做同样事需配 library、libraryTarget、externals 三组字段不是“新就是好”,关键看工程约束是否被 Vite 覆盖。
require.context 动态导入或 __webpack_require__ 运行时 API —— Vite 不支持,也没等
.proto、.gql)并注入 JS,Webpack 的 raw-loader 或自定义 loader 更灵活;Vite 要靠插件 + transform 钩子模拟,调试成本高webpack-chain 配置或 CI 中固化了 Webpack 构建流程,强行迁移可能比优化 Webpack 更费时间真正卡住的往往不是功能缺失,而是那些没写进文档的边界行为:比如 Vite 对 worker: { type: 'module' } 的支持在某些版本存在缓存 bug,或者 Webpack 的 HotModuleReplacementPlugin 在 monorepo 中路径解析异常——这些细节,查 issue 比读文档管用。