91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3有什么優勢

發布時間:2021-10-26 09:07:25 來源:億速云 閱讀:133 作者:小新 欄目:開發技術

這篇文章主要介紹了Vue3有什么優勢,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1、源碼

1.1 monorepo

源碼管理方式采用monorepo的方式進行管理,monorepo 把這些模塊拆分到不同的 package 中,每個 package 有各自的 API、類型定義和測試。這樣使得模塊拆分更細化,職責劃分更明確,模塊之間的依賴關系也更加明確,開發人員也更容易閱讀、理解和更改所有模塊源碼,提高代碼的可維護性

1.2 TypeScript

Vue2時期選擇的是flow,由于flow自身存在一些功能上的短板,且TS發展勢頭更好,Vue3選擇使用TS編寫代碼,也可以更好的支持TS提升開發體驗

2、性能

2.1 優化源碼體積

主要從兩個方面進行了源碼體積優化:

移除一些冷門API,比如 filterinline-template

API減少,必然會減少代碼體積,這點非常容易理解

引入tree-shaking 減少打包體積

tree-shaking 依賴 ES2015 模塊語法的靜態結構(即 import export),通過編譯階段的靜態分析,找到沒有引入的模塊并打上標記,這個技術在webpack等打包工具上已經非常普及

在Vue3中的應用:我們大概率不會使用Vue提供的全部API,總會有一些冷門的、業務場景單一使用不到的API,那么在打包的過程中就可以將這些沒有被用戶使用的API移除,減少打包體積

2.3 Proxy

Vue2之前使用Object.defineProperty進行數據劫持

Object.defineProperty(source, key, {
  get(){
    // todo...
  },
  set(){
    // todo...
  }
})

其存在一些缺陷

  • 必須預先知道劫持的key是什么,并不能很好的監聽到對象屬性的添加、刪除

  • 初始化時遞歸遍歷整個data,導致深層嵌套數據結構造成性能負擔,

  • Vue3使用Proxy進行數據劫持,可以很好的規避Object.defineProperty帶來的缺陷

p = new Proxy(source, {
  get() {
    // todo...
  },
  set() {
    // todo...
  }
})

2.4 Composition API

Vue3 在語法方面進行了優化,主要是提供了 Composition API替換原本的Options API

Options API提供了 methodscomputeddataprops以及各個階段的生命鉤子選項,開發者可以在每個API中做著對應的事情,各司其職,上手和理解成本非常低,對于新手開發者非常友好。使用其開發小型項目時代碼的閱讀性、維護性等也是可觀的,但是當遇到大型項目或者較為復雜的業務邏輯時,代碼將會變得非常難以維護,常常導致修改一個功能需要在代碼中跳轉多個地方,一個功能的代碼分散在各個地方,造成閱讀和理解成本直線增加,Composition API,它有一個很好的機制去解決這樣的問題,就是將某個邏輯關注點相關的代碼全都放在一個函數里,這樣當需要修改一個功能時,就不再需要在文件中跳來跳去

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Vue3有什么優勢”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连江县| 通许县| 马边| 额济纳旗| 安图县| 九龙城区| 浦北县| 许昌县| 岱山县| 扎鲁特旗| 威远县| 辽阳县| 临桂县| 宕昌县| 交口县| 桦甸市| 永安市| 金溪县| 抚州市| 瓦房店市| 辽宁省| 临城县| 肥东县| 克东县| 滨海县| 盐山县| 馆陶县| 绥阳县| 临湘市| 新沂市| 张掖市| 连平县| 成安县| 英山县| 西城区| 雷州市| 车险| 颍上县| 秦安县| 张北县| 汝阳县|