Vue源碼學(xué)習(xí)第一期——前期準(zhǔn)備

小提示

剛開始看源碼的時(shí)候,一定不要揪著每行代碼去看搬味,一定要不求甚解境氢,先順著一條主線去捋清思路蟀拷,然后再根據(jù)自己的理解,分析一些重要的實(shí)現(xiàn)萍聊。不然就會(huì)陷入迷茫问芬,欸,這行干嘛的寿桨,啊此衅,這行也不知道。算了亭螟,不看了挡鞍。
舉個(gè)vue的例子,都知道vue是根據(jù)數(shù)據(jù)狀態(tài)變化后预烙,產(chǎn)生virtual DOM的方式更新DOM墨微,那么如果你不清楚virtual DOM的實(shí)現(xiàn)原理,那就不要去細(xì)究virtual DOM的內(nèi)容扁掸∏滔兀可以先往下梳理思路。

目錄分析

vue源碼是托管在github上的也糊,大家可以自己去找炼蹦。雖然目前vue都更新到3.0了,但2.0目前畢竟是主流狸剃,而且大家使用較多,也方便大家去理解具體的思路狗热。所以本次源碼采用的是vue2.6.9钞馁。


vue代碼目錄

相信很多人跟我一樣,第一次看到vue源碼目錄的時(shí)候匿刮,都感覺頭大僧凰。大部分文件夾都不知道是干嘛用的。一般我們會(huì)從package.json文件中看起熟丸。
package.json主要看scripts 字段和 devDependencies 以及 dependencies 字段训措,通過(guò) scripts 字段我們可以知道項(xiàng)目中定義的腳本命令。通過(guò) devDependencies 和 dependencies 字段我們可以了解項(xiàng)目的依賴情況光羞。


package.json

vue是采用rollup打包的绩鸣,rollup是類似于webpack的打包工具,但比webapck更為輕量級(jí)纱兑,缺點(diǎn)是rollup只對(duì)js生效呀闻,并不像webpack還可以對(duì)圖片、css打包潜慎。
如果項(xiàng)目有依賴項(xiàng)的話捡多,我們可以運(yùn)行npm i安裝依賴蓖康。再根據(jù)script的命令去查找運(yùn)行路徑。

當(dāng)然一般優(yōu)秀的項(xiàng)目都會(huì)有貢獻(xiàn)規(guī)則文檔垒手,里面描述的很清晰蒜焊。Vue也不例外:https://github.com/vuejs/vue/blob/dev/.github/CONTRIBUTING.md,在這個(gè)文檔里說(shuō)明了一些行為準(zhǔn)則科贬,PR指南泳梆,Issue Reporting 指南,Development Setup 以及 項(xiàng)目結(jié)構(gòu)唆迁。通過(guò)閱讀這些內(nèi)容鸭丛,我們可以了解項(xiàng)目如何開始,如何開發(fā)以及目錄的說(shuō)明唐责,下面是對(duì)重要目錄和文件的簡(jiǎn)單介紹鳞溉,這些內(nèi)容你都可以去自己閱讀獲取:

├── build --------------------------------- 構(gòu)建相關(guān)的文件鼠哥,一般情況下我們不需要?jiǎng)?├── dist ---------------------------------- 構(gòu)建后文件的輸出目錄
├── examples ------------------------------ 存放一些使用Vue開發(fā)的應(yīng)用案例
├── flow ---------------------------------- 類型聲明熟菲,使用開源項(xiàng)目 [Flow](https://flowtype.org/)
├── package.json -------------------------- 不解釋
├── test ---------------------------------- 包含所有測(cè)試文件
├── src ----------------------------------- 這個(gè)是我們最應(yīng)該關(guān)注的目錄,包含了源碼
│   ├── runtime--------------------------- 包含了不同的構(gòu)建或包的入口文件
│   │   ├── web-runtime.js ---------------- 運(yùn)行時(shí)構(gòu)建的入口朴恳,輸出 dist/vue.common.js 文件抄罕,不包含模板(template)到render函數(shù)的編譯器,所以不支持 `template` 選項(xiàng)于颖,我們使用vue默認(rèn)導(dǎo)出的就是這個(gè)運(yùn)行時(shí)的版本呆贿。大家使用的時(shí)候要注意
│   │   ├── web-runtime-with-compiler.js -- 獨(dú)立構(gòu)建版本的入口,輸出 dist/vue.js森渐,它包含模板(template)到render函數(shù)的編譯器
│   │   ├── web-compiler.js --------------- vue-template-compiler 包的入口文件
│   │   ├── web-server-renderer.js -------- vue-server-renderer 包的入口文件
│   ├── compiler -------------------------- 編譯器代碼的存放目錄做入,將 template 編譯為 render 函數(shù)
│   │   ├── parser ------------------------ 存放將模板字符串轉(zhuǎn)換成元素抽象語(yǔ)法樹的代碼
│   │   ├── codegen ----------------------- 存放從抽象語(yǔ)法樹(AST)生成render函數(shù)的代碼
│   │   ├── optimizer.js ------------------ 分析靜態(tài)樹,優(yōu)化vdom渲染
│   ├── core ------------------------------ 存放通用的同衣,平臺(tái)無(wú)關(guān)的代碼
│   │   ├── observer ---------------------- 反應(yīng)系統(tǒng)竟块,包含數(shù)據(jù)觀測(cè)的核心代碼
│   │   ├── vdom -------------------------- 包含虛擬DOM創(chuàng)建(creation)和打補(bǔ)丁(patching)的代碼
│   │   ├── instance ---------------------- 包含Vue構(gòu)造函數(shù)設(shè)計(jì)相關(guān)的代碼
│   │   ├── global-api -------------------- 包含給Vue構(gòu)造函數(shù)掛載全局方法(靜態(tài)方法)或?qū)傩缘拇a
│   │   ├── components -------------------- 包含抽象出來(lái)的通用組件
│   ├── server ---------------------------- 包含服務(wù)端渲染(server-side rendering)的相關(guān)代碼
│   ├── platforms ------------------------- 包含平臺(tái)特有的相關(guān)代碼
│   ├── sfc ------------------------------- 包含單文件組件(.vue文件)的解析邏輯,用于vue-template-compiler包
│   ├── shared ---------------------------- 包含整個(gè)代碼庫(kù)通用的代碼

大概了解了重要目錄和文件之后耐齐,我們就可以查看 Development Setup 中的常用命令部分浪秘,來(lái)了解如何開始這個(gè)項(xiàng)目了,我們可以看到這樣的介紹:

# watch and auto re-build dist/vue.js
$ npm run dev

# watch and auto re-run unit tests in Chrome
$ npm run dev:test

現(xiàn)在埠况,我們只需要運(yùn)行 npm run dev 即可監(jiān)測(cè)文件變化并自動(dòng)重新構(gòu)建輸出 dist/vue.js耸携,然后運(yùn)行 npm run dev:test 來(lái)測(cè)試。不過(guò)為了方便询枚,我會(huì)在 examples 目錄新建一個(gè)例子违帆,然后引用 dist/vue.js 這樣,我們可以直接拿這個(gè)例子一邊改Vue源碼一邊看自己寫的代碼想怎么玩怎么玩金蜀。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刷后,一起剝皮案震驚了整個(gè)濱河市的畴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尝胆,老刑警劉巖丧裁,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異含衔,居然都是意外死亡煎娇,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門贪染,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)缓呛,“玉大人,你說(shuō)我怎么就攤上這事杭隙∮窗恚” “怎么了?”我有些...
    開封第一講書人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵痰憎,是天一觀的道長(zhǎng)票髓。 經(jīng)常有香客問我,道長(zhǎng)铣耘,這世上最難降的妖魔是什么洽沟? 我笑而不...
    開封第一講書人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮蜗细,結(jié)果婚禮上裆操,老公的妹妹穿的比我還像新娘。我一直安慰自己炉媒,他們只是感情好跷车,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著橱野,像睡著了一般。 火紅的嫁衣襯著肌膚如雪善玫。 梳的紋絲不亂的頭發(fā)上水援,一...
    開封第一講書人閱讀 50,096評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音茅郎,去河邊找鬼蜗元。 笑死,一個(gè)胖子當(dāng)著我的面吹牛系冗,可吹牛的內(nèi)容都是我干的奕扣。 我是一名探鬼主播,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼掌敬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼惯豆!你這毒婦竟也來(lái)了池磁?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤楷兽,失蹤者是張志新(化名)和其女友劉穎地熄,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芯杀,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡端考,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了揭厚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片却特。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖筛圆,靈堂內(nèi)的尸體忽然破棺而出裂明,到底是詐尸還是另有隱情,我是刑警寧澤顽染,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布漾岳,位于F島的核電站,受9級(jí)特大地震影響粉寞,放射性物質(zhì)發(fā)生泄漏尼荆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一唧垦、第九天 我趴在偏房一處隱蔽的房頂上張望捅儒。 院中可真熱鬧,春花似錦振亮、人聲如沸巧还。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)麸祷。三九已至,卻和暖如春褒搔,著一層夾襖步出監(jiān)牢的瞬間阶牍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工星瘾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留走孽,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓琳状,卻偏偏與公主長(zhǎng)得像磕瓷,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容