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

相关推荐
哟哟耶耶21 小时前
Plugin-webpack内置功能split-chunks-plugin配置打包代码分割
前端·webpack·node.js
青梅主码21 小时前
给 AI 打个分,就能搞出估值17亿独角兽??刚刚完成1.5亿美元A轮融资,这个AI 评测平台彻底火了!LMArena
前端
GUIRH21 小时前
Vue指令
前端
林恒smileZAZ21 小时前
前端技巧:检测到省略号文本自动显示 Tooltip
开发语言·前端·javascript
Zzz不能停21 小时前
阻止冒泡和阻止元素默认行为的区别
开发语言·前端·javascript
攀登的牵牛花21 小时前
前端向架构突围系列 - 架构方法(三):前端设计文档的写作模式
前端·架构
m0_5287238121 小时前
如何避免多次调用同一接口
前端·javascript·vue.js·性能优化
小高00721 小时前
Elips:领域模型与 DSL 设计实践:从配置到站点的优雅映射
前端·javascript·后端
远瞻。21 小时前
【博客】前端新手如何创建自己的个人网站相册
前端·docker·博客·反向代理
青莲84321 小时前
Java并发编程基础与进阶(线程·锁·原子类·通信)
android·前端·面试