首页 > 其他 > 详细

对象的defineProperty方法

时间:2019-11-03 22:32:03      阅读:68      评论:0      收藏:0      [点我收藏+]
作用: 设置对象属性的值,或者修改对象属性的值,并且返回该对象。

Object.defineProperty(obj, prop, descriptor)
  • obj: 对象名称
  • prop: 要设置的属性名
  • descriptor: 将被定义或修改的属性描述符,该参数是一个对象,该对象常见设置四个属性的值。
    1.  value:属性对应的值
    2. writeable:该属性是否可以被重写。
    3. configurable:控制第三个参数对象中其他的属性是否能改变,只有为true 的时候,其他值(value ,writeable,enumerable)的值才能被改变,对象的该属性才能被删除。
    4. enumerable:只有该值为 true 的时候该属性才能被枚举出来。
<script>
    var obj = { name: ‘123‘, age: 18 }
    Object.defineProperty(obj, ‘name‘, {
      value: ‘zs‘,
      writable: false,
      configurable: true,
      enumerable: false
    })
    console.log(obj) // {age: 18, name: "zs"}

    // 如果对象设置了defineProperty,只有在 writable 的值为 true 的时候才能通过 点 的方式修改属性值
    obj.name = ‘hhh‘
    console.log(obj) // {age: 18, name: "zs"}

    // 如果对象设置了defineProperty,只有在 configurable 的值为 true 才能删除该属性
    delete obj.name
    console.log(obj) // {age: 18}

    // 如果对象设置了defineProperty,只有在 configurable 的值为 true 才能通过 value 方式重新赋值
    bject.defineProperty(obj, ‘name‘, {
      value: ‘hhh‘
    })
    console.log(obj) // {age: 18, name: "hhh"}

    // 只有当 enumerable 为true 的时候才能被枚举出来
    console.log(Object.keys(obj)) // ["age"]
  </script>

对象的defineProperty方法

原文:https://blog.51cto.com/13701875/2447405

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!