全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

vue.js利用Object.defineProperty实现双向绑定

Object.defineProperty这个方法了不起啊,vue.js是通过它实现双向绑定的。。而且Object.observe也被草案发起人撤回了。。所以defineProperty更有必要了解一下了。

几行代码看他怎么用

var a= {}
Object.defineProperty(a,"b",{
 value:123
})
console.log(a.b);//123

很简单,它接受三个参数,而且都是必填的。。

传入参数

第一个参数:目标对象
第二个参数:需要定义的属性或方法的名字。
第三个参数:目标属性所拥有的特性。(descriptor)

前两个参数不多说了,一看代码就懂,主要看第三个参数descriptor,看看有哪些取值

descriptor

他又以下取值,我们简单认识一下,后面例子,挨个介绍。

  • value:属性的值(不用多说了)
  • writable:如果为false,属性的值就不能被重写,只能为只读了
  • configurable:总开关,一旦为false,就不能再设置他的(value,writable,configurable)
  • enumerable:是否能在for...in循环中遍历出来或在Object.keys中列举出来。
  • get:一会细说
  • set:一会细说

descriptor 默认值

我们再看看第一个例子

var a= {}
Object.defineProperty(a,"b",{
 value:123
})
console.log(a.b);//123

我们只设置了 value,别的并没有设置,但是第一次的时候 可以简单的理解为(暂时这样理解)它会默认帮我们把writable,configurable,enumerable。都设上值,而且值还都是false。。也就是说,上面代码和下面是等价的的(仅限于第一次设置的时候)。

var a= {}
Object.defineProperty(a,"b",{
 value:123,
 writable:false,
 enumerable:false,
 configurable:false
})
console.log(a.b);//123

以上非常重要哦。。并且以上理解对set 和 get 不起作用哦

configurable

总开关,第一次设置 false 之后,,第二次什么设置也不行了,比如说

var a= {}
Object.defineProperty(a,"b",{
 configurable:false
})
Object.defineProperty(a,"b",{
 configurable:true
})
//error: Uncaught TypeError: Cannot redefine property: b

就会报错了。

注意上面讲的默认值。。。如果第一次不设置它会怎样。。会帮你设置为false。。所以。。第二次。再设置他会怎样?。。对喽,,会报错

writable

如果设置为fasle,就变成只读了。

var a = {}; 

Object.defineProperty(o, "b", { 
 value : 123,
 writable : false });

console.log(a.b); // 打印 37
a.b = 25; // 没有错误抛出(在严格模式下会抛出,即使之前已经有相同的值)
console.log(o.a); // 打印 37, 赋值不起作用。

enumerable

属性特性 enumerable 定义了对象的属性是否可以在 for...in 循环和 Object.keys() 中被枚举。

var a= {}
Object.defineProperty(a,"b",{
 value:3445,
 enumerable:true
})
console.log(Object.keys(a));// 打印["b"]

改为false

var a= {}
Object.defineProperty(a,"b",{
 value:3445,
 enumerable:false //注意咯这里改了
})
console.log(Object.keys(a));// 打印[]

for...in 类似,不赘述了

set 和 get

在 descriptor 中不能同时设置访问器(get 和 set)和 wriable 或 value,否则会错,就是说想用 get 和 set,就不能用 writable 或 value 中的任何一个。

set 和 get,他俩干啥用的的。

var a= {}
Object.definePrope`请输入代码`rty(a,"b",{
 set:function(newValue){
 console.log("你要赋值给我,我的新值是"+newValue)
 },
 get:function(){
 console.log("你取我的值")
 return 2 //注意这里,我硬编码返回2
 }
})
a.b =1 //打印 你要赋值给我,我的新值是1
console.log(a.b) //打印 你取我的值
     //打印 2 注意这里,和我的硬编码相同的

简单来说,这个 “b” 赋值或者取值的时候会分别触发 set 和 get 对应的函数。

这就是实现observe的关键啊。

下一篇,我会分析vue的observe的实现源码,聊聊自己如何一步一步实现$watch。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue.js  # Object.defineProperty  # 双向绑定  # 使用Object.defineProperty实现简单的js双向绑定  # JavaScript的Object.defineProperty详解  # js中Object.defineProperty()方法的不详解  # vue.js的双向数据绑定Object.defineProperty方法的神奇之处  # 深入浅出JS的Object.defineProperty()  # js 通过Object.defineProperty() 定义和控制对象属性  # 都是  # 给我  # 第一个  # 你要  # 就不  # 第三个  # 会报  # 设置为  # 它会  # 读了  # 抛出  # 默认值  # 不起作用  # 我会  # 这就是  # 说了  # 遍历  # 不多  # 帮你  # 下了 


相关文章: 如何在万网自助建站平台快速创建网站?  已有域名如何免费搭建网站?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  制作旅游网站html,怎样注册旅游网站?  定制建站流程解析:需求评估与SEO优化功能开发指南  如何彻底卸载建站之星软件?  建站之星后台管理如何实现高效配置?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  油猴 教程,油猴搜脚本为什么会网页无法显示?  如何在建站主机中优化服务器配置?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  建站之星如何修改网站生成路径?  ,网站推广常用方法?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  如何选择适合PHP云建站的开源框架?  TestNG的testng.xml配置文件怎么写  建站VPS能否同时实现高效与安全翻墙?  如何用PHP工具快速搭建高效网站?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  深圳网站制作案例,网页的相关名词有哪些?  制作网站的模板软件,网站怎么建设?  如何快速生成凡客建站的专业级图册?  建站三合一如何选?哪家性价比更高?  建站之星安装后界面空白如何解决?  南平网站制作公司,2025年南平市事业单位报名时间?  高端网站建设与定制开发一站式解决方案 中企动力  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  定制建站价位费用解析与套餐推荐全攻略  建站之星收费标准详解:套餐费用及年费价格表一览  个人摄影网站制作流程,摄影爱好者都去什么网站?  网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?  浅谈Javascript中的Label语句  建站主机数据库如何配置才能提升网站性能?  如何在IIS服务器上快速部署高效网站?  如何解决VPS建站LNMP环境配置常见问题?  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  b2c电商网站制作流程,b2c水平综合的电商平台?  威客平台建站流程解析:高效搭建教程与设计优化方案  如何快速查询网站的真实建站时间?  如何快速登录WAP自助建站平台?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  如何用IIS7快速搭建并优化网站站点?  建站主机SSH密钥生成步骤及常见问题解答?  实例解析Array和String方法  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  Bpmn 2.0的XML文件怎么画流程图  如何通过可视化优化提升建站效果?  如何通过PHP快速构建高效问答网站功能? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。