极客时间对于推广渠道会有返利优惠,比如山月在极客时间买了一门课,再把课程分享给好友购买,这时极客时间会向山月返利20元左右。
而我现在做了一个返利平台,你可以在上边通过山月的链接购买课程,此时极客时间会向我返利。为了共同学习,而你可以添加我的微信 (shanyue94),我将把极客时间给我的返利发一个红包全部返给你

# 简述 Object.defineProperty

Issue

欢迎在 Issue 中交流与讨论: Issue 564 (opens new window)

与直接为一个对象的属性赋值(o.a = 3)不同,Object.defineProperty 可更为精确,拥有更多选项地为对象属性赋值

属性描述符拥有两种: 数据描述符与存取描述符

# 数据描述符 (data descriptor)

决定该属性值是否可写

const o = {}
Object.defineProperty(o, 'a', {
  configurable: false,
  enumerable: false,
  writable: true,
  value: 3,
})
  • configurable: 是否可被删除
  • enumerable: 是否可被枚举,不可枚举属性无法通过 Object.keys 获取到
  • writable: 是否可更改该属性值
  • value: 该属性值的值

当我们使用赋值运算符为对象添加属性时,实际上是添加了一个数据描述符

> o.c = 5
> Object.getOwnPropertyDescriptor(o, 'c')
< {value: 5, writable: true, enumerable: true, configurable: true}

# 存取描述符 (accessor descriptor)

可对对象属性进行拦截,Vue2 的数据绑定原理便是基于此

const o = {}
Object.defineProperty(o, 'a', {
  configurable: false,
  enumerable: false,
  get () {
     return this._a
  },
  set (a) {
    this._a = a * 10
  }
})

关于山月

我的项目:
我的微信:shanyue94,欢迎交流
Last Updated: 6/17/2021, 2:42:18 AM