[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 实现对象的双向绑定的思路不同,需要注意二者之间的区别。

相关推荐
如果超人不会飞几秒前
TinyVue 组件库实战指南:从安装到上手一篇就够了
vue.js
掘金者阿豪几秒前
终于!我的第二本书正式出版,吃透 Agentic AI 核心不踩坑
javascript·后端
开飞机的舒克_4 分钟前
vue3+router动态权限路由
前端·vue.js
VitoChang5 分钟前
放弃手搓路由吧!用 SolidStart 搞 SPA,真香
前端
GuWenyue5 分钟前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
三乐2287 分钟前
事件循环是什么东西,一篇文章带你了解
前端·javascript
wuhen_n8 分钟前
RAG 核心:向量嵌入与本地向量数据库实战
前端·langchain·ai编程
孟陬10 分钟前
国外技术周刊 #139:LLM 正在杀死程序员的「懒惰美德」
前端·人工智能·后端
七牛云行业应用18 分钟前
Codex CLI 和 Codex 桌面端完整教程:两种入口的功能对比与选择指南
前端·后端·github
kisshyshy20 分钟前
告别 Node 噩梦?用 Bun + TypeScript 像写诗一样调用大模型
前端·typescript