JavaScript-Object.defineProperty函数

JavaScript-Object.defineProperty函数

语法

  • Object.defineProperty(obj, prop, descriptor)

    • obj: 要操作的对象
    • prop: 要操作的对象的属性名字
    • descriptor: 官方文档给的名字是描述符,我更喜欢叫他为配置对象
  • descriptor配置对象中的所有参数

参数默认值作用配置属性存取数据
configurablefalse为true时,以后才能修改属性(prop)的配置
enumerablefalse为true时,才可以枚举
writablefalse为true时,才可以修改属性的值
valueundefined任何有效值(字符串、函数等)
getundefined是一个函数,如果读取该属性触发,会有返回值
setundefined是一个函数,如果设置该属性触发

解释

  • 配置属性、存取数据打勾打叉的意思就是不能同时存在,比如你写了get和set,就不能写writable属性的意思。

例子

/**
 * @Auther: kjprime
 * @Date: 2022/8/2
 * @Description: Object.defineProperty例子
 * @version: 1.0.0
 */

const obj1 = {"name": "kjprime"}
// 配置属性
Object.defineProperty(obj1, "name", {
    configurable: true,
    enumerable: true,
    writable: false,
    value: "KjPrime"
})
console.log("obj1.name:", obj1.name)


const obj2 = {"name": "kjprime"}
// 存取数据
Object.defineProperty(obj2, "name", {
    configurable: true,
    enumerable: true,
    get(){
        console.log("我在访问obj2.name的数据,我给他返回我自定义的值")
        return "obj2自定义的值"
    },
    set(value){
        console.log("我在修改obj2.name的数据,把它修改成:", value)
    }
})

console.log(obj2.name)
obj2.name = "KjPrime"
console.log(obj2.name)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值