Vue中的Object.defineProperty详解

Vue中的Object.defineProperty是一个比较重要的方法,它是可以定义对象中属性的一个方法,相比于在对象中直接定义的对象,它更具有灵活性。

直接定义对象中的属性是这样的:

javascript 复制代码
 let person = {
        name:'张三',
        address:'广东',
        age:12,
   } 

而Object.defineProperty可以直接在上面的对象中添加属性,如下面所示:

javascript 复制代码
 Object.defineProperty(person,'age',{
        enumerable:true,//该对象的属性是否能被遍历,默认是false
        writable:true,//该属性是否能被修改,默认是false
        configurable:false,//该属性是否能被删除,默认是false
    })

如果用上面的方法进行定义属性的,属性就能变得更加灵活多变。

javascript 复制代码
 let number = 13;

    Object.defineProperty(person,'age',{
        // enumerable:true,
        // writable:true,
        // configurable:false,
        get:function(){
           console.log("有人在读取该属性值");
           return number;
        },
        set:function(value){
           console.log("有人在修改该属性值");
           number = value;
        }
    })

而上面的方法也可以对对象进行灵活的修改和读取。

相关推荐
wanzhong23333 分钟前
开发日记14-vite配置多环境
服务器·前端·vue
Jinuss6 分钟前
源码分析之React中的Fiber节点介绍
前端·javascript·react.js
SJLoveIT6 分钟前
xss攻击复习总结
前端·xss
放逐者-保持本心,方可放逐7 分钟前
react 之 useState 和 useEffect 应用
前端·javascript·react.js·usestate·useeffect
集成显卡10 小时前
Bun v1.3.6 发布:内置 Tarball 归档支持、JSONC 解析、Bundle 分析增强等重磅更新!
javascript·新版本·bun.js
奔跑的web.10 小时前
TypeScript Enum 类型入门:从基础到实战
前端·javascript·typescript
盐真卿10 小时前
python2
java·前端·javascript
梦梦代码精10 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
刘一说11 小时前
Vue3 组合式 API(Composition API):逻辑复用的革命性实践
vue.js·vue
seabirdssss11 小时前
《bootstrap is not defined 导致“获取配置详情失败”?一次前端踩坑实录》
前端·bootstrap·html