這篇文章主要講解了vue的commit解析,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。
創(chuàng)新互聯(lián)業(yè)務(wù)包括:成品網(wǎng)站、企業(yè)產(chǎn)品展示型網(wǎng)站建設(shè)、高端網(wǎng)站設(shè)計、電子商務(wù)型網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)(多語言)、商城網(wǎng)站定制開發(fā)、按需網(wǎng)站建設(shè)、營銷型網(wǎng)站等。效率優(yōu)先,品質(zhì)保證,用心服務(wù)是我們的核心價值觀,我們將繼續(xù)以良好的信譽為基礎(chǔ),秉承穩(wěn)固與發(fā)展、求實與創(chuàng)新的精神,為客戶提供更全面、更優(yōu)質(zhì)的互聯(lián)網(wǎng)服務(wù)!為什么寫這篇vue的分析文章?
對于天資愚鈍的前端(我)來說,閱讀源碼是件不容易的事情,畢竟有時候看源碼分析的文章都看不懂。每次看到大佬們用了1~2年的vue就能掌握原理,甚至精通源碼,再看看自己用了好幾年都還在基本的使用階段,心中總是羞愧不已。如果一直滿足于基本的業(yè)務(wù)開發(fā),怕是得在初級水平一直待下去了吧。所以希望在學(xué)習(xí)源碼的同時記錄知識點,可以讓自己的理解和記憶更加深刻,也方便將來查閱。
目錄結(jié)構(gòu)
本文以vue的第一次 commit a879ec06 作為分析版本
├── build │ └── build.js // `rollup` 打包配置 ├── dist │ └── vue.js ├── package.json ├── src // vue源碼目錄 │ ├── compiler // 將vue-template轉(zhuǎn)化為render函數(shù) │ │ ├── codegen.js // 遞歸ast提取指令,分類attr,style,class,并生成render函數(shù) │ │ ├── html-parser.js // 通過正則匹配將html字符串轉(zhuǎn)化為ast │ │ ├── index.js // compile主入口 │ │ └── text-parser.js // 編譯{{}} │ ├── config.js // 對于vue的全局配置文件 │ ├── index.js // 主入口 │ ├── index.umd.js // 未知(應(yīng)該是umd格式的主入口) │ ├── instance // vue實例函數(shù) │ │ └── index.js // 包含了vue實例的初始化,compile,data代理,methods代理,watch數(shù)據(jù),執(zhí)行渲染 │ ├── observer // 數(shù)據(jù)訂閱發(fā)布的實現(xiàn) │ │ ├── array.js // 實現(xiàn)array變異方法,$set $remove 實現(xiàn) │ │ ├── batcher.js // watch執(zhí)行隊列的收集,執(zhí)行 │ │ ├── dep.js // 訂閱中心實現(xiàn) │ │ ├── index.js // 數(shù)據(jù)劫持的實現(xiàn),收集訂閱者 │ │ └── watcher.js // watch實現(xiàn),訂閱者 │ ├── util // 工具函數(shù) │ │ ├── component.js │ │ ├── debug.js │ │ ├── dom.js │ │ ├── env.js // nexttick實現(xiàn) │ │ ├── index.js │ │ ├── lang.js │ │ └── options.js │ └── vdom │ ├── dom.js // dom操作的封裝 │ ├── h.js // 節(jié)點數(shù)據(jù)分析(元素節(jié)點,文本節(jié)點) │ ├── index.js // vdom主入口 │ ├── modules // 不同屬性處理函數(shù) │ │ ├── attrs.js // 普通attr屬性處理 │ │ ├── class.js // class處理 │ │ ├── events.js // event處理 │ │ ├── props.js // props處理 │ │ └── style.js // style處理 │ ├── patch.js // node樹的渲染,包括節(jié)點的加減更新處理,及對應(yīng)attr的處理 │ └── vnode.js // 返回最終的節(jié)點數(shù)據(jù) └── webpack.config.js // webpack配置
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。