乐趣区

关于javascript:Vue-32正式发布拿来吧你

前言

8 月 5 日,Vue.js 作者尤雨溪在博客上发表 Vue.js 3.2 版本正式公布。

咱们很快乐地发表“Vue.js 3.2”的公布!此版本包含许多重要的新性能和性能改良,并且不蕴含重大更改。

新的 SFC 性能

对于单文件组件(SFC,即.vue 文件)的两项性能曾经由试验状态正式毕业,现提供稳固版本:

  • <script setup> 是一种编译时语法糖,可在 SFC 内应用 Composition API 时极大地改善开发者体验。
  • <style> v-bind在 SFC<style>标签中启用组件状态驱动的动静 CSS 值。

上面是这两个新性能的示例

<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>

感兴趣的敌人,能够浏览它们的文档:

  • https://v3.vuejs.org/api/sfc-script-setup.html
  • https://v3.vuejs.org/api/sfc-style.html#state-driven-dynamic-css

在此基础上<script setup>,咱们还有一个新的 RFC,通过启用编译器的糖改良 ref 应用体验。

Web 组件

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 的反馈性零碎进行了一些重大的性能改良。具体来说:

  • 更高效的 ref 实现(约 260% 的读取速度 / 约 50% 的写入速度)
  • 晋升约 40% 依赖项跟踪速度
  • 内存使用量缩小约 17%

模板编译器也失去了一些改良:

  • 创立一般元素 VNode 的速度进步了约 200%
  • 更踊跃的继续晋升 hoisting 1

最初,有一个新的 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 获取更多详细信息。

Effect Scope API

3.2 引入了一个新的Effect Scope API,用于间接管制反馈性成果(计算和观察者)的解决工夫。它能够更轻松地在组件上下文之外利用 Vue 的响应式 API,并且还解锁了组件外部的一些高级用例。

这是次要面向库作者的低级 API,因而倡议浏览该性能的 RFC 以理解此性能的动机和用例。

无关 3.2 中所有更改的具体列表,请参阅残缺的更改日志。

对于我

大家好,我是星野。欢送加我微信 qqlcx55 或者关注我的公众号前端有道 点击能够扫码,学习交换。

退出移动版