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() 定义和控制对象属性
# 都是
# 给我
# 第一个
# 你要
# 就不
# 第三个
# 会报
# 设置为
# 它会
# 读了
# 抛出
# 默认值
# 不起作用
# 我会
# 这就是
# 说了
# 遍历
# 不多
# 帮你
# 下了
相关文章:
如何用美橙互联一键搭建多站合一网站?
官网建站费用明细查询_企业建站套餐价格及收费标准指南
如何用虚拟主机快速搭建网站?详细步骤解析
如何用腾讯建站主机快速创建免费网站?
如何选择香港主机高效搭建外贸独立站?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
用v-html解决Vue.js渲染中html标签不被解析的问题
昆明高端网站制作公司,昆明公租房申请网上登录入口?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
如何获取免费开源的自助建站系统源码?
深圳网站制作案例,网页的相关名词有哪些?
如何配置IIS站点权限与局域网访问?
安云自助建站系统如何快速提升SEO排名?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何生成腾讯云建站专用兑换码?
如何确认建站备案号应放置的具体位置?
如何快速建站并高效导出源代码?
h5在线制作网站电脑版下载,h5网页制作软件?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
建站VPS能否同时实现高效与安全翻墙?
如何有效防御Web建站篡改攻击?
建站之星如何一键生成手机站?
如何在阿里云ECS服务器部署织梦CMS网站?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
seo网站制作优化,网站SEO优化步骤有哪些?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何在阿里云通过域名搭建网站?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
如何使用Golang安装API文档生成工具_快速生成接口文档
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
如何快速搭建虚拟主机网站?新手必看指南
历史网站制作软件,华为如何找回被删除的网站?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
深圳网站制作培训,深圳哪些招聘网站比较好?
如何通过NAT技术实现内网高效建站?
如何通过VPS建站无需域名直接访问?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何快速选择适合个人网站的云服务器配置?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
深入理解Android中的xmlns:tools属性
GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?
购物网站制作公司有哪些,哪个购物网站比较好?
建站主机如何安装配置?新手必看操作指南
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
长沙企业网站制作哪家好,长沙水业集团官方网站?
定制建站哪家更专业可靠?推荐榜单揭晓
*请认真填写需求信息,我们会在24小时内与您取得联系。