淺談Vue3的幾個優(yōu)勢
Vue2已經(jīng)非常優(yōu)秀,且具備完善的社區(qū)和生態(tài),但是Vue3仍然在源碼、性能和語法 API 三個大的方面進(jìn)行了優(yōu)化
1、源碼
1.1 monorepo
源碼管理方式采用monorepo的方式進(jìn)行管理,monorepo 把這些模塊拆分到不同的 package 中,每個 package 有各自的 API、類型定義和測試。這樣使得模塊拆分更細(xì)化,職責(zé)劃分更明確,模塊之間的依賴關(guān)系也更加明確,開發(fā)人員也更容易閱讀、理解和更改所有模塊源碼,提高代碼的可維護(hù)性
1.2 TypeScript
Vue2時期選擇的是flow,由于flow自身存在一些功能上的短板,且TS發(fā)展勢頭更好,Vue3選擇使用TS編寫代碼,也可以更好的支持TS提升開發(fā)體驗
2、性能
2.1 優(yōu)化源碼體積
主要從兩個方面進(jìn)行了源碼體積優(yōu)化:
移除一些冷門API,比如 filter、inline-template 等
API減少,必然會減少代碼體積,這點(diǎn)非常容易理解
引入tree-shaking 減少打包體積
tree-shaking 依賴 ES2015 模塊語法的靜態(tài)結(jié)構(gòu)(即 import 和 export),通過編譯階段的靜態(tài)分析,找到?jīng)]有引入的模塊并打上標(biāo)記,這個技術(shù)在webpack等打包工具上已經(jīng)非常普及
在Vue3中的應(yīng)用:我們大概率不會使用Vue提供的全部API,總會有一些冷門的、業(yè)務(wù)場景單一使用不到的API,那么在打包的過程中就可以將這些沒有被用戶使用的API移除,減少打包體積
2.3 Proxy
Vue2之前使用Object.defineProperty進(jìn)行數(shù)據(jù)劫持
Object.defineProperty(source, key, {
get(){
// todo...
},
set(){
// todo...
}
})
其存在一些缺陷
- 必須預(yù)先知道劫持的
key是什么,并不能很好的監(jiān)聽到對象屬性的添加、刪除 - 初始化時遞歸遍歷整個
data,導(dǎo)致深層嵌套數(shù)據(jù)結(jié)構(gòu)造成性能負(fù)擔(dān), Vue3使用Proxy進(jìn)行數(shù)據(jù)劫持,可以很好的規(guī)避Object.defineProperty帶來的缺陷
p = new Proxy(source, {
get() {
// todo...
},
set() {
// todo...
}
})
2.4 Composition API
Vue3 在語法方面進(jìn)行了優(yōu)化,主要是提供了 Composition API替換原本的Options API
Options API提供了 methods、computed、data、props以及各個階段的生命鉤子選項,開發(fā)者可以在每個API中做著對應(yīng)的事情,各司其職,上手和理解成本非常低,對于新手開發(fā)者非常友好。使用其開發(fā)小型項目時代碼的閱讀性、維護(hù)性等也是可觀的,但是當(dāng)遇到大型項目或者較為復(fù)雜的業(yè)務(wù)邏輯時,代碼將會變得非常難以維護(hù),常常導(dǎo)致修改一個功能需要在代碼中跳轉(zhuǎn)多個地方,一個功能的代碼分散在各個地方,造成閱讀和理解成本直線增加,Composition API,它有一個很好的機(jī)制去解決這樣的問題,就是將某個邏輯關(guān)注點(diǎn)相關(guān)的代碼全都放在一個函數(shù)里,這樣當(dāng)需要修改一個功能時,就不再需要在文件中跳來跳去
到此這篇關(guān)于淺談Vue3的幾個優(yōu)勢的文章就介紹到這了,更多相關(guān)Vue3優(yōu)勢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)動態(tài)顯示與隱藏底部導(dǎo)航的方法分析
這篇文章主要介紹了vue實(shí)現(xiàn)動態(tài)顯示與隱藏底部導(dǎo)航的方法,結(jié)合實(shí)例形式分析了vue.js針對導(dǎo)航隱藏與顯示的路由配置、事件監(jiān)聽等相關(guān)操作技巧,需要的朋友可以參考下2019-02-02
詳解Vue項目編譯后部署在非網(wǎng)站根目錄的解決方案
這篇文章主要介紹了Vue項目編譯后部署在非網(wǎng)站根目錄的解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04
手寫Vue內(nèi)置組件component的實(shí)現(xiàn)示例
本文主要介紹了手寫Vue內(nèi)置組件component的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
解決betterScroll在vue中存在圖片時,出現(xiàn)拉不動的問題
今天小編就為大家分享一篇解決betterScroll在vue中存在圖片時,出現(xiàn)拉不動的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09

