javascript - 关于defineProperty的value
问题描述
> var a = {}> Object.defineProperty(a, 'b', {... value: 110}){}> a{}> a.b110> a.b = 555555> a.b110> var aa = {b: 1}undefined> Object.defineProperty(aa, 'b', {... value: 119}){ b: 119 }> aa.b119> aa.b = 11> aa.b1
为什么aa.b可更改,a.b不能?
问题解答
回答1:属性描述符有三个属性分别是 configurable enumerable writable,默认值均为 false而使用对象字面量定义的属性描述符均为 true,可以通过 Object.getOwnPropertyDescriptor(a, ’b’) 及 Object.getOwnPropertyDescriptor(aa, ’b’) 来获取两个属性的描述符。
所以 a.b 不可修改,aa.b 可以修改。
回答2:因为默认情况下,通过Object.defineProperty()定义的属性的属性值均为false是不可写的.
a = {}Object.getOwnPropertyDescriptor(a, ’b’)// > undefinedObject.defineProperty(a, 'b', {value: 119})Object.getOwnPropertyDescriptor(a, ’b’)// > Object {value: 119, writable: false, enumerable: false, configurable: false}
而通过对象字面量定义的属性默认是可写的,调用`
aa = { b: 1 }Object.getOwnPropertyDescriptor(aa, ’b’)// > Object {value: 1, writable: true, enumerable: true, configurable: true}
所以aa的b属性是可写的. 所以Object.defineProperty()并不改变属性的属性值.所以aa的b的值会改变.
相关文章:
1. linux - 编译安装mysql 5.6.232. angular.js - vue中类似于angular的ng-change的指令是?3. html5 - 在一个页面中 初始了两个swiper 不知道哪里错了 一直不对4. PHP能实现百度网盘的自动化么?5. android - 使用vue.js进行原生开发如何进行Class绑定6. node.js - 微信的自动回复问题7. node.js - vue服务端渲染如何部署到线上8. css3 - 请问一下在移动端CSS布局布局中通常需要用到哪些元素,属性?9. 网页爬虫 - python requests爬虫,如何post payload10. 如何把3个不同的MySQL数据库数据整合到一个MySQL数据库中?
