尤雨溪官宣 Vue 3.2 已发布

news/2024/7/10 2:49:07 标签: vue, js, javascript, java, python
js_content">


技术编辑:典典丨发自 思否编辑部

公众号:SegmentFault


近日,尤雨溪在微博平台官宣 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 中所有更改的详细列表,请参阅完整的更改日志。

日志地址:

https://github.com/vuejs/vue-next/blob/master/CHANGELOG.md

原链接:

https://blog.vuejs.org/posts/vue-3.2.html

点个在看支持我吧,转发就更好了


http://www.niftyadmin.cn/n/1251215.html

相关文章

Springboot中你用Xstream和JAXB方式xml与bean相互转换

在现今的项目开发中&#xff0c;虽然数据的传输大部分都是用json格式来进行传输&#xff0c;但是xml毕竟也会有一些老的项目在进行使用&#xff0c;正常的老式方法是通过获取节点来进行一系列操作&#xff0c;个人感觉太过于复杂、繁琐。推荐一套简单的api--XStream类。在理解了…

Shiro过滤器配置(ShiroFilterFactoryBean)

这篇博客就是记录一下shiro过滤器的配置和一些注意事项 /*** Shiro过滤器配置*/Bean(name "shiroFilter")public ShiroFilterFactoryBean shiroFilter() {ShiroFilterFactoryBean shiroFilter new ShiroFilterFactoryBean();// Shiro的核心安全接口,这个属性是必须…

CSS 即将支持嵌套,SASS/LESS 等预处理器已无用武之地?

最近&#xff0c;有一则非常振奋人心的消息&#xff0c;CSS 即将原生支持嵌套 -- Agenda to publish FPWD of Nesting[1]&#xff0c;表示 CSS 嵌套规范即将进入规范的 FWPD 阶段。目前对应的规范为 -- CSS Nesting Module[2]。随着 CSS 自定义属性&#xff08;CSS Variable&am…

shiro的拦截器机制

拦截器介绍 Shiro使用了与Servlet一样的Filter接口进行扩展&#xff1b;所以如果对Filter不熟悉可以参考《Servlet3.1规范》http://www.iteye.com/blogs/subjects/Servlet-3-1了解Filter的工作原理。首先下图是Shiro拦截器的基础类图&#xff1a; 1、NameableFilter Nameable…

12 道腾讯前端面试真题及答案整理

金九银十&#xff0c;又到了跳槽季啦&#xff0c;该刷题走起了。这里总结了一些被问到可能会懵逼的面试真题&#xff0c;有需要的可以看下&#xff5e;1. 谈谈你对 dns-prefetch 的理解DNS 是什么-- Domain Name System&#xff0c;域名系统&#xff0c;作为域名和IP地址相互映…

VUE项目问题之:去掉url中的#/

一、问题 使用VUE路由&#xff0c;项目的url总是带有锚点&#xff0c;如下&#xff1a; http://localhost:8082/#/二、解决 修改路由文件中 index.js 文件&#xff0c;即 src --> router --> index.js 没修改前&#xff1a; export default new Router({routes: [{path…

Windows安装使用Openssl

1. OpenSSL官网 官方下载地址&#xff1a; https://www.openssl.org/source/ 2. Windows安装方法 OpenSSL官网没有提供windows版本的安装包&#xff0c;可以选择其他开源平台提供的工具。例如 http://slproweb.com/products/Win32OpenSSL.html 以该工具为例&#xff0c;安装步…

一行可以让项目启动快 70% 以上的代码(实用)

转自&#xff1a;作者 - rexkentzhenghttps://juejin.cn/post/6961203055257714702前言这两天闲来无事&#xff0c;想优化优化项目的启动时间&#xff0c;用了一个下午吧&#xff0c;将项目启动时间从48秒优化到14秒&#xff0c;大约70左右&#xff0c;效果还是有的&#xff0c…