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

几行代码看他怎么用
var a= {}
Object.defineProperty(a,"b",{
value:123
})
console.log(a.b);//123
很简单,它接受三个参数,而且都是必填的。。
传入参数
第一个参数:目标对象
第二个参数:需要定义的属性或方法的名字。
第三个参数:目标属性所拥有的特性。(descriptor)
前两个参数不多说了,一看代码就懂,主要看第三个参数descriptor,看看有哪些取值
descriptor
他又以下取值,我们简单认识一下,后面例子,挨个介绍。
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小时内与您取得联系。