面试官:说说Webpack和Vite有哪些区别

 更新时间:2026年04月03日 09:42:31   作者:404星球的猫  
Vite基于ESM实现按需编译,开发启动和热更新速度极快,Webpack采用全量打包,适合复杂项目但启动较慢,这篇文章主要介绍了Webpack和Vite有哪些区别的相关资料,需要的朋友可以参考下

面试官:说说 Webpack 和 Vite 的区别

按“真实项目里踩过的坑”来回答,分 7 个场景

1. 第一次npm run dev

  • Webpack
    公司老项目(约 4 万行业务代码 + Ant Design Pro):

    > webpack serve
    95% emitting CompressionPlugin

    冷启动 38 s,M1 芯片 + SSD。
    原因:

    • 要解析 2 300 个模块的依赖图;
    • ts-loader、babel-loader、eslint-loader 串行排队;
    • 每次新增文件,图重新计算。
  • Vite
    同一套代码迁移到 Vite:

    > vite
    ready in 823 ms

    预构建依赖(esbuild 一次性把 lodash-esantd 等打包成 ESM)只要 200 ms,剩下的模块按浏览器请求懒编译。

2. 热更新(HMR)

  • Webpack
    修改一个 Button 组件样式:

    • 触发 less-loader → css-loader → MiniCssExtractPlugin
    • 全量 diff 依赖图,平均 2.8 s 浏览器才刷出来。
      如果改的是公共 util,时间飙到 6 s+。
  • Vite
    只编译改动的那 1 个 .vue 文件,esbuild 把 <style> 内联成 ESM,200 ms 内浏览器收到更新。
    实测:React 项目 300+ 路由页,HMR 稳定在 300 ms 内。

3. 配置地狱

  • Webpack
    为了兼容 IE11,我们写了 160 行的 webpack.config.js

    module.exports = {
      entry: { main: ['core-js/stable', 'regenerator-runtime/runtime', './src/index.tsx'] },
      output: { publicPath: process.env.ASSET_PATH || '/' },
      module: {
        rules: [
          { test: /\.tsx?$/, use: ['babel-loader', 'eslint-loader'] },
          { test: /\.less$/, use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader', 'less-loader'] },
          { test: /\.(png|jpg|jpeg|gif|svg)$/, type: 'asset', parser: { dataUrlCondition: { maxSize: 8192 } } }
        ]
      },
      plugins: [
        new HtmlWebpackPlugin({ template: './public/index.html' }),
        new CompressionPlugin({ algorithm: 'gzip' })
      ],
      optimization: {
        splitChunks: {
          chunks: 'all',
          cacheGroups: {
            vendor: { test: /[\\/]node_modules[\\/]/, name: 'vendors', priority: 10 }
          }
        }
      }
    };

    新人 2 天才能跑起来。

  • Vite

    export default defineConfig({
      plugins: [react()],
      server: { port: 3000 },
      build: { outDir: 'dist' }
    });

    30 秒上手,剩下交给官方插件。

4. 生产构建

  • Webpack
    npm run build 跑 3 min 10 s,产物 4.2 MB(gzip 后 1.1 MB)。

    • 需要手动配 SplitChunksPluginBundleAnalyzerPlugin 做体积优化;
    • 多入口时要做 runtimeChunk: 'single',否则重复 polyfill 爆炸。
  • Vite
    同一套代码,Rollup 构建 38 s,产物 3.8 MB(gzip 后 0.9 MB)。

    • 默认 tree-shaking 更激进,Ant Design 的未使用组件直接消失;
    • 动态 import 自动拆包,无需手写魔法注释。

5. 兼容性

  • Webpack
    能无痛打到 ES5,IE11 白屏率 < 1%。
    代价:polyfill + 降级语法,打包体积 +25%。

  • Vite
    开发阶段默认只支持现代浏览器(ES2020+)。
    需要 IE11 时:

    • @vitejs/plugin-legacy
    • 会自动生成 legacy bundle + polyfill,构建时间 + 40%,但 DX 仍比 Webpack 快。

6. 微前端/Module Federation

  • Webpack 5
    我们主应用用 ModuleFederationPlugin 动态加载子应用:
    new ModuleFederationPlugin({
      name: 'host',
      remotes: {
        marketing: 'marketing@http://localhost:3001/remoteEntry.js'
      }
    })
    子应用独立部署,共享 React、antd,节省 300 KB 流量。
    Vite 目前社区有 vite-plugin-federation,但功能、稳定性还没对齐 Webpack,复杂场景慎入。

7. 迁移成本

  • Webpack → Vite
    我们 3 人 2 周把 70% 的子项目迁完:
    • webpack-dev-server 代理配置抄到 vite.config.ts
    • file-loader/url-loader 换成 import.meta.glob
    • 遇到 CommonJS 老库(如 moment)加 optimizeDeps.include 强制预构建。
      遗留的 30%(Module Federation 子应用、低版本浏览器)继续留在 Webpack。

一句话总结

  • 新项目、小团队、追求开发效率 → 直接上 Vite。
  • 要 IE11、Module Federation、超大型 monorepo → 继续 Webpack,或两者并存:主应用 Webpack,子应用 Vite。

到此这篇关于Webpack和Vite有哪些区别的文章就介绍到这了,更多相关Webpack和Vite区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 前端图片加载错误的多种原因分析

    前端图片加载错误的多种原因分析

    在浏览网页或使用应用程序时,图片加载失败是一个常见的问题,下面这篇文章主要介绍了前端图片加载错误的多种原因分析的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-03-03
  • JavaScript实现页面电子时钟

    JavaScript实现页面电子时钟

    这篇文章主要为大家详细介绍了JavaScript实现页面电子时钟,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • JavaScript使用Ajax上传文件的示例代码

    JavaScript使用Ajax上传文件的示例代码

    本篇文章主要介绍了JavaScript使用Ajax上传文件的示例代码,详细的介绍了两种上传方式,感兴趣的小伙伴可以了解一下
    2017-08-08
  • Rxjs TakeUntil 操作符内容梳理总结

    Rxjs TakeUntil 操作符内容梳理总结

    这篇文章主要介绍了Rxjs TakeUntil操作符内容梳理总结,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • 分享19个JavaScript 有用的简写写法

    分享19个JavaScript 有用的简写写法

    最近很火的一篇来自国外的文章,js的简写写法一定程度上可以提高你的js书写水平对于js的理解也会更近一步
    2017-07-07
  • 浅谈js函数中的实例对象、类对象、局部变量(局部函数)

    浅谈js函数中的实例对象、类对象、局部变量(局部函数)

    下面小编就为大家带来一篇浅谈js函数中的实例对象、类对象、局部变量(局部函数)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • 利用js实现在浏览器状态栏显示访问者在本页停留的时间

    利用js实现在浏览器状态栏显示访问者在本页停留的时间

    本文为大家介绍下利用JavaScript实现在浏览器状态栏显示停留时间即在状态栏上显示访问者在本页停留的时间
    2013-12-12
  • JS实现图片懒加载(lazyload)过程详解

    JS实现图片懒加载(lazyload)过程详解

    这篇文章主要介绍了JS实现图片懒加载(lazyload)过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • 高性能JavaScript循环语句和条件语句

    高性能JavaScript循环语句和条件语句

    这篇文章主要为大家介绍了高性能JavaScript循环语句和条件语句,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • javascript异步处理工作机制详解

    javascript异步处理工作机制详解

    笼统地说,异步在javascript就是延时执行。严格来说,javascript中的异步编程能力都是由BOM与DOM提供的,如setTimeout,XMLHttpRequest,还有DOM的事件机制,等等很多。这些东西都有一个共同的特点,就是拥有一个回调函数,实现控制反转。
    2015-04-04

最新评论