一篇文章說清 webpack、vite、vue-cli、create-vue 的區別

金色海洋(jyk)發表於2022-05-09

webpack、vite、vue-cli、create-vue 這些都是什麼?看著有點暈,不要怕,我們一起來分辨一下。

先看這個表格:

腳手架 vue-cli create-vue
構建專案 vite
打包程式碼 webpack rollup
  • 腳手架:建立專案,選擇性安裝需要的外掛,指定統一的風格,生成demo。
  • 構建專案:建立專案的執行環境,需要手動安裝外掛。
  • 打包程式碼:程式碼寫好之後,為了更好的使用,需要打包處理一下。

是不是有了一個整體的感覺?我們再來詳細的看一下。

vue-cli

官網:https://cli.vuejs.org/zh/index.html

Vue CLI 的包名稱由 vue-cli 改成了 @vue/cli

vue-cli 是 Vue 早期推出的一款腳手架,使用 webpack 建立 Vue 專案,可以選擇安裝需要的各種外掛,比如 Vuex、VueRouter等。

vue-cli 用於建立 vue2 的專案;
@vue/cli 用於建立 vue3 的專案,當然也支援 vue2。

使用起來還是比較繁瑣的,首先要安裝腳手架,然後使用 vue create hello-world 建立專案,具體的就不介紹了。

create-vue

官網:https://staging-cn.vuejs.org/guide/quick-start.html#with-build-tools

create-vue 是 Vue3 的專用腳手架,使用 vite 建立 Vue3 的專案,也可以選擇安裝需要的各種外掛,使用更簡單。

使用方式

npm init vue@latest
or
yarn create vue

可選外掛

然後我們可以選擇需要的各種外掛:

  • TypeScript
  • JSX Support
  • Vue Router for Single Page Application development
  • Pinia for state management
  • Vitest for Unit testing
  • Cypress for both Unit and End-to-End testing
  • ESLint for code quality
  • Prettier for code formating

官方最新文件已經看不到 vue-cli 的身影了,只有 create-vue 的使用方式,所以大家可以放心食用。

vite

官網:https://cn.vitejs.dev/

Vite(法語意為 "快速的",發音 /vit/ ,發音同 "veet")是一種新型前端構建工具,能夠顯著提升前端開發體驗。它主要由兩部分組成:

使用 vite 不僅可以建立 vue 的專案,而且可以建立 react 等專案,只是需要手動安裝第三方外掛,有點麻煩。

目前支援的模板預設如下:

JavaScript TypeScript
vanilla vanilla-ts
vue vue-ts
react react-ts
preact preact-ts
lit lit-ts
svelte svelte-ts

rollup

官網:https://rollupjs.org/guide/en/

rollup 是一種打包工具,特點就是,打的包非常精簡,體積小。
官網是英文的,中文資料也比較少,不過好在常規用法可以參考 vite的官網。

webpack

尤雨溪在知乎的一次回答(https://www.zhihu.com/question/477139054/answer/2156019180)裡提到:

webpack core 是一個純打包工具(對標 Rollup),而 Vite 其實是一個更上層的工具鏈方案,對標的是 (webpack + 針對 web 的常用配置 + webpack-dev-server)。

webpack core 因為只針對打包不預設場景,所以設計得極其靈活,不侷限於針對 web 打包,幾乎所有可配置的環節都做成了可配置的。這種極度的靈活性對於一些特定場景依然不可替代。
但反過來導致的缺點就是配置項極度複雜,外掛機制和內部邏輯晦澀難懂,針對常見的 web 也需要大量的配置。

另外大量 loader 外掛雖然單獨釋出卻存在各種隱式耦合,很容易配置不當互相影響。對於新手來說,把 webpack 從零開始配到跟 Vite 開箱即用功能對等的程度根本是不可能的任務,所以大部分團隊/公司要麼用的是基於 webpack 包一層的腳手架(umi, vue-cli),或是專門養一個人稱 webpack 配置工程師的角色。

小結

webpack 是一個全能選手,啥都能幹,只是有點複雜,對新手不太友好。
Rollup 是後起之秀,打包更簡潔。
vite 把 rollup 變成了“開袋即食”,便於新手入門。
create-vue 基本取代了 vue-cli,除非你想建立 vue2 的專案。

所以,想建立一個 vue3 的專案,首選 create-vue,非常方便快捷,建立的專案也可以統一風格。

相關文章