vue3.5新增特性

1.响应式内部源码优化

2.Props的解构

  • 比较方便设置默认值
  • 解构后依旧是响应式
javascript 复制代码
// 子组件
const { message = "默认值message", count = 0 } = defineProps({
	message:String,
	count: Number
})

// 编译器会自动对解构变量(message,count)的访问编译到props.count中,因此在访问时会跟踪它
// 所有在watch解构的props时,需要放到getter中

watch( () => count, (newV) => {
	console.log("count发生变化",newV)
})

3.SSR优化

4.自定义元素改善

5.其他相关特性

  • useTemplateRef
javascript 复制代码
// template
<input type="text" ref="customKey">
<button @click="focus">获取焦点</button>
// script

import { useTemplateRef } from "vue"
const inputRef = useTemplateRef("customKey")
const focus = () => {
	inputRef.value.focus()
}
  • defer Teleport
javascript 复制代码
// teleport组件作用是挂载到目标元素下
// 内置teleport组件的约束为:在挂载teleport组件时,其目标元素必须存在。意思是目标元素必须在teleport之前
// 在3.5中加入了defer属性,它会在渲染周期之后挂载它
<Teleport defer to="#targetEl">
	<div>挂载的的内容</div>
</Teleport>

<div id="targetEl"></div>
  • onWatcherClearup
javascript 复制代码
// 当我们侦听某个数据,并在数据改变后操作,如果我们多次触发,想只保留最后一次。
// 比如,我们侦听id改变获取数据,多次触发,想只根据最后id请求获取数据,取消之前的请求

<button @click="id++">id 改变</button>


import {ref,watch,onWatcherClearup} from "vue"
const id = ref(0)

watch(id,(newV)=>{
	const timer = setTimeOut(()=>{
		// 多次连续点击,只会打印最后一次
		console.log("根据id获取的结果",newV)
	},2000)
	// 清除上一次watch
	onWatcherClearup(()=>{
    	clearTime(timer)
    })
})
相关推荐
老华带你飞1 分钟前
博物馆展览门户|基于Java博物馆展览门户系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
PineappleCoder6 分钟前
别让页面 “鬼畜跳”!Google 钦点的 3 个性能指标,治好了我 80% 的用户投诉
前端·性能优化
卤代烃20 分钟前
🕹️ [AI] Chrome DevTools MCP 原理分析
前端·mcp
梦里不知身是客1132 分钟前
flink对于迟到数据的处理
前端·javascript·flink
卤代烃43 分钟前
🤝 了解 CDP (Chrome DevTools Protocol):browser-use 背后的隐藏功臣
前端·chrome·puppeteer
一 乐1 小时前
人事管理系统|基于Springboot+vue的企业人力资源管理系统设计与实现(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·后端
b***74881 小时前
前端状态系统的时代变革:从本地状态到全局状态,再到智能状态的未来趋势
前端·状态模式
秋氘渔1 小时前
Vue 3 组合式API中的生命周期钩子函数介绍
前端·javascript·vue.js
拉不动的猪1 小时前
requestAnimationFrame 与 JS 事件循环:宏任务执行顺序分析
前端·javascript·面试
步步为营DotNet1 小时前
深度解析C# 11的Required成员:编译期验证保障数据完整性
java·前端·c#