Object.defineProperty 仅能为对象的单个已有属性添加 getter/setter 拦截,适用于精确控制读写行为(如日志、校验),但无法拦截新增/删除属性、数组操作或嵌套对象,Vue 2 基于此实现响应式,Vue 3 则改用 Proxy 全面替代。可以用 Object.defineProperty 为对象的**单个属性**添加 getter/setter 拦截器,但无法直接拦截对象的新增属性、删除属性、枚举等整体操作------那是 Proxy 的职责。重点在于:它适用于精确控制某个已有属性的读写行为。为已有属性添加 getter/setter 拦截这是最常用场景:在不改变属性值的前提下,插入自定义逻辑(如日志、校验、依赖收集)。必须先确保目标属性存在(或用 configurable: true 允许后续修改) 调用 Object.defineProperty(obj, key, descriptor),其中 descriptor 至少含 get 或 set 若原属性是可写的,建议保留 writable: false(因为定义了 getter/setter 后,writable 自动失效)示例:const obj = { name: 'Alice' };Object.defineProperty(obj, 'name', { get() { console.log('读取 name'); return this._name || ''; }, set(val) { console.log('设置 name 为:', val); this._name = String(val).trim(); }, configurable: true // 允许后续重新定义});obj.name = ' Bob '; // 输出:设置 name 为: Bob console.log(obj.name); // 输出:读取 name → 'Bob'给新属性添加拦截(非覆盖原有值)如果对象原本没有该属性,也能用 defineProperty 添加带拦截器的属性,但需注意默认不可枚举、不可配置、不可写。 Tellers AI Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
weixin_459753942 小时前
PHP源码运行需要独立显卡吗_显卡对PHP执行有无影响【解答】CLX05052 小时前
如何自动同步SQL异构表数据_利用触发器实现实时数据复制gCode Teacher 格码致知2 小时前
Python教学:正则表达式的寻找、匹配、替换、删除 四种模式案例-由Deepseek产生倔强的石头1062 小时前
异构操作系统架构下的数据库表空间高级管理:路径兼容与自动化运维实战2301_779622412 小时前
Golang如何解析嵌套JSON_Golang嵌套JSON解析教程【简明】m0_748554812 小时前
C#怎么使用CancellationToken C#如何用取消令牌优雅地取消异步任务和长时间操作【进阶】阿洛学长2 小时前
使用 Hexo+GitHub 搭建个人免费博客教程(小白)m0_624578592 小时前
PHP怎么实现X-XSS-Protection头_PHP浏览器XSS过滤【操作】MongoDB 数据平台2 小时前
破解车联网数据管理困局,MongoDB助力长城汽车构建车联数智化核心引擎