[Vue3] 对象的双向绑定

在 Vue2 中习惯用 computed + getter + setter 实现数据的双向绑定:

javascript 复制代码
computed: {
	someData: {
		get() { return this.xxProp },
		set(newVal) { emit('input', newVal) }
	}
}

结果到 Vue3 发现等价的代码失效了:

javascript 复制代码
const props = defineProps({
	modelValue: { 
		type: Object, 
		default: () => ({name: 'xxx'})
	}
})

const user = computed({
	get => props.modelValue,
	set(newVal) => emit('update:modelValue', newVal)
})

// update:modelValue 事件不会触发
user.name = 'abc'

原因是 Vue3 的 computed 无法监听对象属性的修改(而且也没类似 watch 的 deep 选项),因此 Vue2 那套用 computed 实现双向绑定的思路在 Vue3 需要换成 watch 了:

javascript 复制代码
const props = defineProps({
	modelValue: { 
		type: Object, 
		default: () => ({name: 'xxx'})
	}
})

const user = ref(props.modelValue)

watch(
	() => user, 
	(newVal) => emit('update:modelValue', newVal.value), 
	{ deep: true }
)

// 触发 update:modelValue 
user.name = 'abc'

用 watch 实现双向绑定需要注意如下几点:

  1. props 的值是 rawValue,没有响应式
  2. 不要直接修改 props 的属性,因此这里额外定义了一个 user 变量来保存初始的 prop value
  3. 使用 deep: true 来监听对象属性的变更

如果监听的不是对象,则可以直接用 computed 的方式实现双向绑定

总结

Vue2 和 Vue3 实现对象的双向绑定的思路不同,需要注意二者之间的区别。

相关推荐
EchoEcho24 分钟前
记录overflow:hidden和scrollIntoView导致的页面问题
前端·css
Cache技术分享26 分钟前
318. Java Stream API - 深入理解 Java Stream 的中间 Collector —— mapping、filtering 和 fla
前端·后端
竟未曾年少轻狂29 分钟前
Vue3 生命周期钩子
前端·javascript·vue.js·前端框架·生命周期
TT哇34 分钟前
【实习】数字营销系统 银行经理端(interact_bank)前端 Vue 移动端页面的 UI 重构与优化
java·前端·vue.js·ui
蓝帆傲亦35 分钟前
Web前端跨浏览器兼容性完全指南:构建无缝用户体验的最佳实践
前端
晴殇i40 分钟前
【前端缓存】localStorage 是同步还是异步的?为什么?
前端·面试
不一样的少年_41 分钟前
Chrome 插件实战:如何实现“杀不死”的可靠数据上报?
前端·javascript·监控
深度涌现41 分钟前
DNS详解——域名是如何解析的
前端
小码哥_常44 分钟前
Android内存泄漏:成因剖析与高效排查实战指南
前端
卤代烃44 分钟前
✨ 形势比人强,Chrome 大佬也去搞 Gemini 了
前端·agent·vibecoding