使用vue3.0 + vite + element-plus搭建項目(vite源碼解讀)

寫在前面

vue3剛出來的時候,就去了解vue3相關語法和使用。最近恰逢公司某新項目啟動,搓搓小手,就采用vue3.0去搭建編寫(不過這個項目用的是vue-cli4腳手架生成的項目,內置webpack,所以寫的時候也只能先用webpack)?,F在項目進程一半有余,也踩了很多坑,感悟了vue3函數編程的魅力。不過!這幾天又癡迷于尤大大力推的vite!本著對新技術的探索和分享精神(哈哈還有蹭Vite的熱度),決定整理一篇vite相關入門和解讀的文章。??

準備工作

1.vue3.0

建議先有一些vue語法知識儲備

在 Vue3.x 是兼容 Vue2.x 的語法的, Vue2.x 的90%語法能正常在 Vue3.x 中運行
從vue2.x到vue3.x,這其實是由完全面向對象OOP的思路,到函數式編程的思想轉變。
Options APIComposition API的轉變。(實在不會使用一些語法糖,就將就使用vue2.x的語法吧)

2. vite

vite工具是寫這篇文章的唯一目的,具體了解可以看看文檔:vue3中文文檔-vite,vite-github
尤大大說Vite是前端下一代打包工具。咱用奧運精神總結就是:更高、更快、更強。???

image.png

在本文的Vite模塊,也會加大篇幅解讀Vite相關的源碼

3.element-plus

文檔地址:Element Plus

Element Plus,一套為開發者、設計師和產品經理準備的基于 Vue 3.0 的桌面端組件庫

開始

1.全局安裝 create-vite-app

yarn global add create-vite-app@1.18.0

或者

npm i -g create-vite-app@1.18.0

2.創建項目目錄

cva program-name

或者

 create-vite-app app-name

// 轉眼間就好了 ,真的很快??

create-vite-app.png

目錄結構:


目錄結構.png

3. 啟動項目

Vite幫我們生成的目錄結構很簡潔,主要文件和 vue-cli 的文件都是一樣的,但是對比 vue-cli 新建的新項目的webpack啟動,Vite啟動真的很快了,甚至說啟動時間可以忽略不計了????????

啟動項目.png

啟動效果.png

4. vite幫我們做了什么事

好家伙,啟動速度快到我根本看不見就好了,所以去代碼扒一扒,vite偷偷做了哪些事情:
index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <link rel="icon" href="/favicon.ico" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Vite App</title>
</head>
<body>
  <div id="app"></div>
  <script type="module" src="/src/main.js"></script>
</body>
</html>

/src/main.js

import { createApp } from 'vue'
import App from './App.vue'
import './index.css'

createApp(App).mount('#app')

其實就是index.html中引?了src/main.js, main.js 引?App.vue并掛載到html中,很好理解的一個流程,打開瀏覽器組件也確實渲染出來了。

Vite 是一個 web 開發構建工具,由于其原生 ES 模塊導入方法,它允許快速提供代碼。

瀏覽器通過<script module>,為每個導??成HTTP請求, vite的dev服務攔截http請求,并把代碼做?些轉換之后返回給瀏覽器進?渲染。簡單來說就是 Vite通過node編譯靜態資源返回給瀏覽器渲染。


http請求.png

5.vite原理是什么:

通過請求內容,其實我們不難看出端倪,首先在我們運?npm run dev之后,vite啟動了?個dev server去攔截我們請求的資源?件,所以我們在瀏覽器看到的??實際上是經過vite處理后的html?件。

5.1. vite先向html內插入代碼

<script type="module">import "/vite/client"</script>

image.png

這個部分順便提一句,教大家如何去閱讀源碼吧:
1.按照啟動命令,去對應的文件夾下面找到入口,如果是自定義的命令,自己肯定知道入口的,初始化的入口都在node_modules內:
圖1.png

2.找到命令的入口,然后順利找到引入的文件cli.js
圖2.png

3.在cli.js內,找到命令后可以看到.action內有具體執行的函數塊。這里如果不明白為什么的,可以看看我寫的一個關于手寫cli的文章 模仿vue-cli,手寫一個腳手架,可以解惑。
圖3.png

4.繼續在cli.js內,找到了runServe函數的具體位置,從而可以看到server的入口是server/index.js
圖4.png

5.在server/index.js繼續閱讀代碼,通過const serverPluginHtml_1 = require("./serverPluginHtml");知道了下一個我們需要去的位置路徑
圖5.png

6.順利找到插入的具體地方
圖6.png

5.2. client建立了一個sokcet服務

image.png

這個client在瀏覽器中啟了?個socket服務,實時的去接受?系列的指令,根據指令再去處理響應的邏輯
connected: socket 連接成功
vue-reload: 組件重新加載
vue-rerender: 組件重新渲染
style-update: 樣式更新
style-remove: 樣式移除
js-update: js ?件更新
full-reload: ??重刷新

例如保存代碼熱更新后,組件重新加載

image.png

直接上源碼解讀,同樣,在圖6的代碼處可以看到熱更新模塊和client模塊


圖7.png

圖8.png

圖9.png

6.element-plus

快速上手:element-plus,

npm install element-plus --save

在 main.js 中寫入以下內容:

import { createApp } from 'vue'
import ElementPlus from 'element-plus';
import 'element-plus/lib/theme-chalk/index.css';
import App from './App.vue';

const app = createApp(App)
app.use(ElementPlus)
app.mount('#app')

去hello-world組件嘗試使用:寫一個el-button,保存。
同時在控制臺可以看到跟上面解讀vite源碼時,client服務所提供的熱更新以及組件刷新邏輯的驗證。


image.png
image.png

驗證成功,ok!


image.png

以上就是自己有關vite的一點理解,感謝閱讀,覺得vite部分說的不錯有收獲的話可以點個贊哈哈。
后續在公司項目結束后,可能會整理開發時vue3和element-plus的相關分享。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,505評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,556評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,463評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,009評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,778評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,218評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,281評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,436評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,969評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,795評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,993評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,537評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,229評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,659評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,917評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,687評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,990評論 2 374

推薦閱讀更多精彩內容