Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升

摘要:
今天凌晨,尤禹锡宣布Vue 3.2已在微博平台发布,并表示:+TS+Volar=Zhengiang Vue 3.2包含许多重要的新功能和性能改进,但不包括重大更改。新的单文件组件函数:<scriptsetup>是一个编译时语法糖,它可以大大提高在SFC中使用Composition API时的工作效率。性能改进由于@basvanmeurs的出色工作,3.2对Vue的反应性系统进行了一些显着的性能改进。Hit允许Vue不仅跳过虚拟DOM差异,还可以完全跳过新VNode的创建。它可以更容易地在组件上下文之外利用Vue的响应API,还可以解锁组件内部的一些高级用例。

今日凌晨,尤雨溪在微博平台官宣 Vue 3.2 已发布,并表示:

<script setup> + TS + Volar = 真香

Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升第1张

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

Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升第2张

服务端渲染

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 中所有更改的详细列表,请参阅完整的更改日志

欢迎关注前端早茶,与广东靓仔携手共同进阶

Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升第3张

前端早茶专注前端,一起结伴同行,紧跟业界发展步伐~

公众号作者:广东靓仔

免责声明:文章转载自《Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇docker镜像仓库一步步把 SAP UI5 应用部署到 SAP BTP Kyma 运行环境中去下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

vue 数组去重

test() { const arr =[ { name: '张三', age: 22}, { name: '李四', age: 22}, { name: '张三', age:...

VS Code中Vetur与prettier、ESLint联合使用

一、vue语法高亮1.1 安装Vetur 1. 创建.vue文件, 写些代码, 发现一片漆黑 2. 安装激活vetur插件, 代码就有高亮了. 右键菜单还会变多一些, 主要多了个格式化文档.   这里配置了多个格式化的,所以会有多个。 看下vetur的特性: 语法高亮, 代码片段(emmet给我的感觉是一个写好了的snippet), 质量提示&...

nginx代理访问vue打包dist碰到的问题

一开始vue项目npm run build打包成dist放在nginx的html目录下面  C:Program FilesJava ginx-1.12.2conf此时我的文件路径是有空格的,Program Files这两个单词之间有空格。  nginx.conf配置文件里面有空格,格式可能比较严格,我一直报404的错误 后来直接把项目文件下的路径复制上...

Vue切换页面时中断axios请求

一、概述 在Vue单页面开发过程中,遇到这样的情况,当我切换页面时,由于上一页面请求执行时间长,切换到该页面时,还未执行完,这时那个请求仍会继续执行直到请求结束,此时将会影响页面性能,并且可能对现在页面的数据显示造成一定影响 所以我们应该,切换页面前中断前面所有请求 二、解决方法 在main.js中,重新封装axios请求,在router.beforeEa...

vue Element动态设置el-menu导航当前选中项

1,npm install vuex --save 2,在src下新建vuex文件夹,新建store.js文件; store.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const state = { count: 0, adminleftnav...

vue的坑

1. (vue2.x以上,1.x没有问题)vue和jq一起使用的冲突:在使用了v-bind: class的元素上,当vue和jq都需要增改class时,用jq加的属性可能无效。 原因:当数据的布尔值改变后(比如某个class需要加上),由于vue是在本次事件轮结束后更新DOM或改变属性,而jq的addClass是同步的,所以jq加上的类名会被vue覆盖。...