Vue3.5 有那些变化?

重构响应式

Vue3.5 中对内部响应式系统进行了重构,内存占用减少了 56%,对于开发行为来说是没有任何改变的。

Props 解构赋值

在之前的版本中,我们为组件设置默认值的过程是这样的;

ts 复制代码
const props = withDefaults(
  defineProps<{
    count?: number
    msg?: string
  }>(),
  {
    count: 0,
    msg: 'Hello Vue3.5',
  }
)

在 Vue3.5 之后,Props 支持解构赋值,大大简化了默认值声明的过程;

ts 复制代码
const { count = 0, msg = 'Hello Vue3.5' } = defineProps<{
  count?: number
  msg?: string
}>()

同时在 Vue3.5 之后可以直接监听 Props 内部的参数

ts 复制代码
watch(
  () => count,
  newValue => {
    console.log('watch ==>', newValue)
  }
)

onEffectCleanup 注册监听回调

在组件卸载或者下一次监听的时候会自动执行 onEffectCleanup 回调函数,而无需在 beforeUnmount 中统一清理,代码结构更加合理。

TS 复制代码
watch(
  () => count,
  newValue => {
    const timer = setTimeout(() => {
      console.log('watch ==>', newValue)
    }, 1000)

    onWatcherCleanup(() => {
      console.log('onWatcherCleanup', count)
      clearTimeout(timer)
    })
  }
)

useTemplateRef 获取元素

在 Vue3.5 之前获取元素是通过 ref 来获取的,既可以创建响应式数据,也可以获取对应的元素,是不符合单一职责原则的。

html 复制代码
<template>
  <input ref="inputRef" />
</template>

<script setup>
import { ref } from 'vue'
const inputRef = ref(null)
</script>

在 Vue3.5 之后的版本中,我们通过 useTemplateRef() 来获取元素

html 复制代码
<template>
  <input ref="input" />
</template>

<script setup>
import { nextTick, ref, useTemplateRef } from 'vue'
const inputRef = useTemplateRef('input')

nextTick(() => {
  console.log(inputRef.value)
})
</script>

Deferred Teleport 延迟传送

在 Vue3.5 之前,我们需要确保 Teleport 传送的元素一定在 Teleport 上下文之前才可以正常工作。

html 复制代码
<template>
  <div id="container"></div>
  <Teleport to="#container">...</Teleport>
</template>

在 Vue3.5 之后我们可以添加 defer 属性来进行延迟传送,无需确保元素上下文位置。

html 复制代码
<template>
  <Teleport defer to="#container">...</Teleport>
  <div id="container"></div>
</template>

总结

Vue3.5 版本已经是默认的版本了,同时也对某些特性场景下进行的优化和新增的功能,总体来说会更加方便,代码结构更加简洁,大家赶快体验起来吧~

最后

感谢你的阅读~

如果你有任何的疑问欢迎您在后台私信,我们一同探讨学习!

如果觉得这篇文章对你有所帮助,点赞、在看是最大的支持!

相关推荐
寻找奶酪的mouse12 分钟前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大19 分钟前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
We་ct21 分钟前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
张3蜂28 分钟前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道29 分钟前
Qt——事件简单介绍
开发语言·前端·qt
广州华水科技31 分钟前
GNSS与单北斗变形监测技术的应用现状分析与未来发展方向
前端
code_YuJun1 小时前
corepack 作用
前端
千寻girling1 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
全栈前端老曹1 小时前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
code_YuJun1 小时前
pnpm-workspace.yaml
前端