如何用 Object.defineProperty 为现有对象添加拦截器

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是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。

相关推荐
Warson_L6 小时前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅6 小时前
海天线算法的前世今生
python·计算机视觉
韩师傅6 小时前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
Warson_L6 小时前
LangGraph的MessageState and HumanMessage
python
韩师傅7 小时前
当你的甲方吐槽天空不够蓝,你应该如何应对
python·计算机视觉
Warson_L7 小时前
python的类&继承
python
Warson_L7 小时前
类型标注/type annotation
python
ThreeS10 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
金銀銅鐵11 小时前
[Python] 模 n 乘法的逆元计算器
python·数学·游戏