App下載

尤雨溪:Vue.js 3.2 已發(fā)布!

尤雨溪 2021-08-21 14:11:49 瀏覽數(shù) (2426)
反饋
原文: https://blog.vuejs.org/posts/vue-3.2.html

我們很高興地宣布 Vue.js 3.2“Quintessential Quintuplets”的發(fā)布!此版本包括許多重要的新功能和性能改進(jìn),并且不包含重大更改。

證監(jiān)會(huì)新功能

單個(gè)文件組件(SFC,又名.vue文件)的兩個(gè)新功能已從實(shí)驗(yàn)狀態(tài)畢業(yè),現(xiàn)在被認(rèn)為是穩(wěn)定的:

  • <script setup> 是一種編譯時(shí)語法糖,可在 SFC 內(nèi)使用 Composition API 時(shí)極大地改善人體工程學(xué)。

  • <style> v-bind在 SFC<style>標(biāo)簽中啟用組件狀態(tài)驅(qū)動(dòng)的動(dòng)態(tài) CSS 值。

這是一起使用這兩個(gè)新功能的示例組件:

<script setup>
import { ref } from 'vue'


const color = ref('red')
</script>


<template>
  <button @click="color = color === 'red' ? 'green' : 'red'">
    Color is: {{ color }}
  </button>
</template>


<style scoped>
button {
  color: v-bind(color);
}
</style>

在SFC Playground 中嘗試一下,或者閱讀它們各自的文檔:

  • <script setup>
  • <style> v-bind 在此基礎(chǔ)上<script setup>,我們還有一個(gè)新的 RFC,用于通過啟用編譯器的糖改進(jìn) ref 使用的人體工程學(xué)。

網(wǎng)絡(luò)組件

Vue 3.2 引入了defineCustomElement一種使用 Vue 組件 API 輕松創(chuàng)建原生自定義元素的新方法:

import { defineCustomElement } from 'vue'


const MyVueElement = defineCustomElement({
  // normal Vue component options here
})


// Register the custom element.
// After registration, all `<my-vue-element>` tags
// on the page will be upgraded.
customElements.define('my-vue-element', MyVueElement)

這個(gè) API 允許開發(fā)者創(chuàng)建 Vue 驅(qū)動(dòng)的 UI 組件庫,這些庫可以與任何框架一起使用,或者根本沒有框架。我們還在我們的文檔中添加了一個(gè)關(guān)于在 Vue 中使用和創(chuàng)建 Web 組件的新部分。

性能改進(jìn) 由于 @basvanmeurs 的出色工作,3.2 對(duì) Vue 的反應(yīng)性系統(tǒng)進(jìn)行了一些重大的性能改進(jìn)。具體來說:

  • 更高效的 ref 實(shí)現(xiàn)(約 260% 的讀取速度/約 50% 的寫入速度)
  • 約 40% 更快的依賴跟蹤
  • 內(nèi)存使用量減少約 17% 模板編譯器也得到了一些改進(jìn):

  • 創(chuàng)建普通元素 VNode 的速度提高了約 200%
  • 更積極的持續(xù)提升 [ 1 ] [ 2 ] 最后,有一個(gè)新v-memo指令提供了記憶模板樹的一部分的能力。一v-memo擊允許Vue公司跳過不僅虛擬 DOM 版本比較,而是創(chuàng)建新的虛擬節(jié)點(diǎn)完全。雖然很少需要,但它提供了一個(gè)逃生艙,以在某些情況下(例如大型v-for列表)擠出最大性能。

的用法v-memo是一行添加,使 Vue 成為js-framework-benchmark 中最快的主流框架之一:

VUE3.2發(fā)布

服務(wù)端渲染

@vue/server-renderer3.2 中的包現(xiàn)在提供了一個(gè) ES 模塊構(gòu)建,它也與 Node.js 內(nèi)置模塊分離。這使得捆綁和利用@vue/server-rendererNode.js 運(yùn)行時(shí)(例如CloudFlare Workers或 Service Workers)成為可能。

我們還改進(jìn)了流式渲染 API,提供了用于渲染到Web Streams API 的新方法。查看文檔以@vue/server-renderer獲取更多詳細(xì)信息。

效果范圍 API

3.2 引入了一個(gè)新的Effect Scope API,用于直接控制反應(yīng)性效果(計(jì)算和觀察者)的處理時(shí)間。它可以更輕松地在組件上下文之外利用 Vue 的響應(yīng)式 API,并且還解鎖了組件內(nèi)部的一些高級(jí)用例。

這是主要面向庫作者的低級(jí) API,因此建議閱讀該功能的RFC以了解此功能的動(dòng)機(jī)和用例。

有關(guān) 3.2 中所有更改的詳細(xì)列表,請(qǐng)參閱完整的更改日志。

推薦課程

0 人點(diǎn)贊