今日凌晨,尤雨溪在微博平台官宣 Vue 3.2 已公布,并示意:
<script setup> + TS + Volar = 真香
Vue 3.2 版本包含许多重要的新性能和性能改良,但 并不蕴含重大更改。
新的单文件组件性能:
<script setup>
是一种编译时语法糖,可在 SFC 内应用 Composition API 时极大地晋升工作效率。
<style> v-bind
在 SFC 标签中启用组件状态驱动的动静 CSS 值。<style>
一起应用这两个新性能的示例组件:
<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>
网络组件
Vue 3.2 引入了一种应用 Vue 组件 API 轻松创立原生自定义元素的新办法:defineCustomElement
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)
这个 API 容许开发者创立 Vue 驱动的 UI 组件库,这些库能够与任何框架一起应用,或者基本没有框架。咱们还在文档中增加了一个对于在 Vue 中应用和创立 Web 组件的新局部。
性能改良
因为 @basvanmeurs 的杰出工作,3.2 对 Vue 的反馈性零碎进行了一些重大的性能改良。具体如下:
- 更高效的 ref 实现(约 260% 的读取速度 / 约 50% 的写入速度)
- 约 40% 更快的依赖跟踪
- 内存使用量缩小约 17%
模板编译器也失去了一些改良:
- 创立一般元素 VNode 的速度进步了约 200%
- 更激进的继续晋升 [1] [2]
最初,有一个新的 v-memo
指令,它提供了记忆模板树的一部分的能力。命中容许 Vue 不仅跳过虚构 DOM 差别,而且齐全跳过新 VNode 的创立。尽管很少须要,但它提供了一个逃生舱来在某些状况下挤出最大性能,例如大型列表. v-memo
v-for
应用单行增加,让 Vue 成为 js-framework-benchmark:v-memo 中最快的支流框架 v-memo
服务端渲染
3.2 中的包当初提供了一个 ES 模块构建,它也与 Node.js 内置模块拆散。这使得捆绑和利用非 Node.js 运行时(例如 CloudFlare Workers 或 Service Workers)成为可能。@vue/server-renderer
@vue/server-renderer
咱们还改良了流式渲染 API,提供了用于渲染到 Web Streams API 的新办法。查看 @vue/server-renderer
的文档以获取更多详细信息。
成果范畴 API
3.2 引入了一个新的 Effect Scope API,用于间接管制反馈性成果(计算和观察者)的解决工夫。它能够更轻松地在组件上下文之外利用 Vue 的响应式 API,并且还解锁了组件外部的一些高级用例。
这是次要面向库作者的低级 API,因而倡议浏览该性能的 RFC 以理解此性能的动机和用例。
无关 3.2 中所有更改的具体列表,请参阅残缺的更改日志。