8 月 5 日,Vue.js 做者尤雨溪在博客上宣布 Vue.js 3.2 版本正式发布。 本文的相关内容为中文翻译。css
原文地址: https://blog.vuejs.org/posts/...
咱们很高兴地宣布 “Vue.js 3.2” 的发布!此版本包括许多重要的新功能和性能改进,而且不包含重大更改。html
关于单文件组件(SFC,即.vue 文件)的两项功能已经由实验状态正式毕业,现提供稳定版本:前端
<script setup>
是一种编译时语法糖,可在 SFC 内使用 Composition API 时极大地改善开发者体验。<style> v-bind
在 SFC<style>
标签中启用组件状态驱动的动态 CSS 值。下面是这两个新功能的示例vue
<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>
感兴趣的朋友,能够阅读它们的文档:segmentfault
在此基础上<script setup>
,咱们还有一个新的 RFC,经过启用编译器的糖改进 ref 使用体验。api
Vue 3.2 引入了defineCustomElement
一种使用 Vue 组件 API轻松建立原生自定义元素的新方法:微信
import { defineCustomElement } from 'vue' const MyVueElement = defineCustomElement({ // 普通Vue组件选项 }) // 注册自定义元素。 // 注册后,全部`<my-vue-element>` 标签 // 页面上的将被升级。 customElements.define('my-vue-element', MyVueElement)
这个 API 容许开发者建立 Vue 驱动的 UI 组件库,这些库能够与任何框架一块儿使用,或者根本没有框架。咱们还在咱们的文档中添加了一个关于在 Vue 中使用和建立 Web 组件的新章节。框架
因为@basvanmeurs
的出色工做,3.2 对 Vue 的反应性系统进行了一些重大的性能改进。具体来讲:post
模板编译器也获得了一些改进:性能
最后,有一个新的 v-memo 指令,它提供了记忆模板树的一部分的能力。命中容许 Vue 不只跳过虚拟 DOM 差别,并且彻底跳过新 VNode 的建立。虽然不多须要,但它提供了一个逃生舱来在某些状况下挤出最大性能,例如大型列表. v-memo v-for
使用单行添加,让 Vue 成为 js-framework-benchmark
中最快的主流框架之一:
@vue/server-renderer3.2
中的包如今提供了一个 ES 模块构建,它也与 Node.js 内置模块分离。
如此一来能够经过@vue/server-renderer
在非 Node.js环境运行(例如CloudFlare Workers或 Service Workers)。
咱们还改进了流式渲染 API,提供了用于渲染到Web Streams API 的新方法。查看文档以@vue/server-renderer
获取更多详细信息。
3.2 引入了一个新的Effect Scope API
,用于直接控制反应性效果(计算和观察者)的处理时间。它能够更轻松地在组件上下文以外利用 Vue 的响应式 API,而且还解锁了组件内部的一些高级用例。
这是主要面向库做者的低级 API,所以建议阅读该功能的RFC以了解此功能的动机和用例。
有关 3.2 中全部更改的详细列表,请参阅完整的更改日志。
你们好,我是星野。欢迎加我微信
qqlcx55
,或者关注个人公众号
前端有道 点击能够扫码,学习交流。