Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Webpack] Webpack vs Vite的核心差异【热度: 820】 #625

Open
yanlele opened this issue Nov 9, 2023 · 0 comments
Open

[Webpack] Webpack vs Vite的核心差异【热度: 820】 #625

yanlele opened this issue Nov 9, 2023 · 0 comments
Labels
工程化 web 项目工程化 腾讯 公司标签
Milestone

Comments

@yanlele
Copy link
Member

yanlele commented Nov 9, 2023

关键词:Webpack vs Vite 差异

构建速度:

  • Webpack: Webpack的构建速度相对较慢,尤其在大型项目中,因为它需要分析整个依赖图,进行多次文件扫描和转译。
  • Vite: Vite以开发模式下的极速构建著称。它利用ES模块的特性,只构建正在编辑的文件,而不是整个项目。这使得它在开发环境下几乎是即时的。

开发模式:

  • Webpack: Webpack通常使用热模块替换(HMR)来实现快速开发模式,但配置相对复杂。
  • Vite: Vite的开发模式非常轻量且快速,支持HMR,但无需额外配置,因为它默认支持。

配置复杂度:

  • Webpack: Webpack的配置相对复杂,特别是在处理不同类型的资源和加载器时。
  • Vite: Vite鼓励零配置,使得项目起步非常简单,但同时也支持自定义配置,使其适用于复杂项目。

插件生态:

  • Webpack: Webpack拥有庞大的插件生态系统,适用于各种不同的需求。
  • Vite: Vite也有相当数量的插件,但相对较小,因为它的开发模式和构建方式减少了对一些传统插件的需求。

编译方式:

  • Webpack: Webpack使用了多种加载器和插件来处理不同类型的资源,如JavaScript、CSS、图片等。
  • Vite: Vite利用ES模块原生支持,使用原生浏览器导入来处理模块,不需要大规模的编译和打包。

应用场景:

  • Webpack: 适用于复杂的大型项目,特别是需要大量自定义配置和复杂构建管道的项目。
  • Vite: 更适用于小到中型项目,或者需要快速开发原型和小型应用的场景。

打包原理:

  • Webpack: Webpack的打包原理是将所有资源打包成一个或多个bundle文件,通常是一个JavaScript文件。
  • Vite: Vite的打包原理是保持开发时的模块化结构,使用浏览器原生的导入机制,在生产环境中进行代码分割和优化。

优缺点:

  • Webpack:

    • 优点:灵活、强大、适用于复杂场景、庞大的插件生态。
    • 缺点:构建速度较慢、配置复杂、开发体验不如Vite流畅。
  • Vite:

    • 优点:极快的开发构建速度、零配置启动、原生ES模块支持、适用于小型项目和快速原型开发。
    • 缺点:插件生态相对较小、不太适用于复杂大型项目。

参考文档

@yanlele yanlele added 工程化 web 项目工程化 腾讯 公司标签 labels Nov 9, 2023
@yanlele yanlele added this to the milestone Nov 9, 2023
@yanlele yanlele changed the title [Webpack] Webpack vs Vite的核心差异【热度: 620】 [Webpack] Webpack vs Vite的核心差异【热度: 820】 Dec 17, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
工程化 web 项目工程化 腾讯 公司标签
Projects
None yet
Development

No branches or pull requests

1 participant