vue数据双向绑定的原理

本文深入探讨了Vue.js中实现双向数据绑定的技术细节,主要涉及Object.defineProperty()的使用,从单向数据绑定到双向数据绑定的实现过程。通过实例展示了如何监听并响应数据变化,以实时更新视图。同时,讲解了Vue内部如何借助发布者-订阅者模式进行数据劫持,确保数据和视图的同步。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

01.Object.defineProperty()

Object.defineProperty()的作用就是直接在一个对象上定义一个新属性,或者修改一个已经存在的属性
Object.defineProperty(obj, prop, desc)
obj 需要定义属性的当前对象
prop 当前需要定义的属性名
desc 属性描述符

02.单向数据绑定

数据变,视图变

<body>
	<h1 id="title"></h1>
	<span id="btn">点击</span>
<script>
let book = {};
let name = "123";
Object.defineProperty(book,"name",{
	set(value){
		name=value
		title.innerHTML=name;
		
	},
	get(value){
		return name
	}
})
let num=0;
btn.onclick=function(){
	book.name=num++;
	console.log(book.name)
}
</script>
</body>

在这里插入图片描述在这里插入图片描述

03.双向数据绑定

视图变,数据变

<body>
	<h1 id="title"></h1>
	<span id="btn">点击</span>
	<input type="" name="" id="test" value="" />
<script>
let book = {};
let name = "123";
Object.defineProperty(book,"name",{
	set(value){
		name=value
		btn.innerHTML=name;
	},
	get(value){
		return name
	}
})
//通过oninput监听input的值变化
test.oninput=function(){
	book.name=this.value;//进入set
	console.log(name)//进入get
}
</script>
</body>

在这里插入图片描述

在这里插入图片描述

04.vue实现双向数据绑定原理

object有个方法叫Object.defineProperty,这个方法可以检测到属性的变化。一旦检测到数据变化就会通知dom更新。其实defineProperty做到了数据劫持,底层发布的时候使用了发布者订阅者模式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值