Vue.js是現代化的JavaScript框架,被廣泛用于構建響應式的單頁面應用和互動的用戶界面。Vue在社區中廣受歡迎,其中一個原因是它的簡單易用性和靈活性。近日,Vue發布了新版本,該版本的一大亮點是對”原音”的消除。
Vue3.0的設計初衷就是更好地處理 TypeScript 和 Flow,也就是說,Vue 3.0 對準備使用 TypeScript 進行編寫的應用程序做了大量的工作。其中最重要的一項工作就是將所有 Reactivity(響應式)的特性從 Vue.js 的核心中分離出來稱為了Vue Reactivity API。新的響應式 API 是為了支持現代編譯器優化(可能采用了 proxys),因此很大程度上消除了 vue2 中原音的消耗。
Vue Reactivity API 內部包含了一些 Recative 內部需要的特定規則和算法。Vue Reactivity API 還使用內存映射的技巧,對于大型應用程序的數據,這將要表現得比 Vue 2.x 更好。該 API 還進一步優化了數據偵聽器和 getter / setter 的性能,使之更快更高效。
Vue3.0 的代碼重構讓我們重新審視了一下 Vue2.x 的性能問題,并在未來優化性能和數據運維方面大有作為。數據運維方面,Vue 3.0 的更改將減少一些對于更新和依賴的遍歷,代替之是對 key-weak maps 的使用。對于平均大小以下的組件,在 Vue3.0 中更新依賴的速度會更快,這將進一步優化我們的編程效率。
另一個非常顯眼的變化是關于組件引用的處理。在 Vue3.0 當中,組件引用已經被極度簡化,無需過多關注組件細節。這是因為 Vue3.0 引入了更多的細節聲明方式,使我們不需通過繁瑣的語句來創建并且引用組件。
如上所述,Vue3.0 對于vue2 中原音的消耗進行了重新設計和優化,通過分離代碼和完善 Vue Reactivity API,大大提升了響應性能力和性能表現,減少了在組件渲染時的原音消耗。此外,在更新數據和依賴方面使用新的 key-weak maps 方法,可以進一步優化平均大小以下的組件的依賴更新速度。同時,Vue3還對組件引用作了大幅度優化,讓我們更有效地進行開發。這是Vue3 發布的一大亮點,也將帶來更出色的開發體驗和運行性能。