vue中最常见的属v-model这个数据双向绑定了,很好奇它是如何实现的呢?尝试着用原生的JS去实现一下。

首先大致学习了解下Object.defineProperty()这个东东吧!
* Object.defineProperty()
* 对对象的属性进行 定义/修改
* */
let obj = {x:10}
// 这两种方式都相对来说比较简单,直接,但是有些时候我们需要对对象的属性的修改和增加进行必要的干预
// obj.y = 20;
// obj.x = 100;
// obj.x = 'abc';
//
// let arr = [1,2,3];
// arr.length = 'abc';//不可更改
// console.log(arr);
// console.log(obj.x);
// delete obj.x;
// console.log(obj);
Object.defineProperty(obj, 'y', {
configurable: false, //设置是否可删除 false为不可删除
value: 100
});
console.log(obj);
delete obj.y;//删除
console.log(obj);
//设置对象某个属性值的时候,顺便设置它的属性。enumerable 可枚举 configurable 可以删除否 writable 可改值否
Object.defineProperty(obj, 'z', {//enumerable 可枚举(没有则新添加)
enumerable: true,//为false时,for..in object.keys json.stringfy 不能取到该z属性
value: 10000
});
for (var attr in obj) {
console.log(attr);
}
Object.defineProperty(obj, 'm', {
writable: false,//可更改
value: 9
});
console.log(obj);
obj.m = 100;
console.log(obj);
以上总结了对象的defineProperty四个属性:configurable,enumerable,value,writable
接下来再深入认识下它的另外两个方法:set 以及get
注意:get和set不能与configurable,enumerable,value,writable同时存在
let obj = {x:10}
let y = 100;
Object.defineProperty(obj, 'y', {
get() {
//当obj的y属性被调用的时候触发,该方法的返回值将作为获取的结果
console.log('get');
return y;
},
set(value) {
//当obj的y属性被设置的时候触发
console.log('set', value);
y = value;
}
})
console.log(obj.y);
obj.y = 1;
console.log(obj.y);
介绍完defineProperty了,最后我们一起看看如何简单的实现数据双向绑定吧!
<body>
<input type="text" id="age">
<h1></h1>
<script>
var ageElement = document.querySelector('#age');
var h1Element = document.querySelector('h1');
let obj = {};
Object.defineProperty(obj, 'age', {
get() {
},
set(value) {
ageElement.value = value;
h1Element.innerHTML = value;
}
})
obj.age = 10;
ageElement.oninput = function() {
obj.age = this.value;
}
</script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue实现双向数据绑定
# vue双向绑定实现原理
# vue双向绑定原理
# Vue数据双向绑定原理实例解析
# Vue的双向数据绑定实现原理解析
# 详解Vue双向数据绑定原理解析
# vue双向数据绑定原理探究(附demo)
# 深入了解Vue中双向数据绑定原理
# 它是
# 我们一起
# 定了
# 这两种
# 能与
# 绑定
# 最常见
# 大家多多
# 到该
# 如何实现
# 解下
# 很好奇
# 返回值
# 总结了
# arr
# console
# vue
# length
# configurable
# false
相关文章:
在线制作视频网站免费,都有哪些好的动漫网站?
如何生成腾讯云建站专用兑换码?
TestNG的testng.xml配置文件怎么写
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
如何在企业微信快速生成手机电脑官网?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
如何用西部建站助手快速创建专业网站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何用PHP快速搭建CMS系统?
微信推文制作网站有哪些,怎么做微信推文,急?
如何零基础在云服务器搭建WordPress站点?
详解jQuery停止动画——stop()方法的使用
如何在阿里云ECS服务器部署织梦CMS网站?
如何用狗爹虚拟主机快速搭建网站?
C#如何使用XPathNavigator高效查询XML
如何选择可靠的免备案建站服务器?
如何设置并定期更换建站之星安全管理员密码?
如何在阿里云虚拟服务器快速搭建网站?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
微信小程序 五星评分(包括半颗星评分)实例代码
电脑免费海报制作网站推荐,招聘海报哪个网站多?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
海南网站制作公司有哪些,海口网是哪家的?
如何快速登录WAP自助建站平台?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
建设网站制作价格,怎样建立自己的公司网站?
一键网站制作软件,义乌购一件代发流程?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
如何挑选高效建站主机与优质域名?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
如何快速搭建个人网站并优化SEO?
非常酷的网站设计制作软件,酷培ai教育官方网站?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
,制作一个手机app网站要多少钱?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
建站主机选购指南与交易推荐:核心配置解析
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
活动邀请函制作网站有哪些,活动邀请函文案?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
建站主机无法访问?如何排查域名与服务器问题
如何在七牛云存储上搭建网站并设置自定义域名?
*请认真填写需求信息,我们会在24小时内与您取得联系。