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是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
曲幽3 小时前
FastAPI 身份验证总踩坑?这份 FastAPI Users “避坑指南”请收好素材积累3 小时前
博士后出站来深可申请的项目补贴等装不满的克莱因瓶3 小时前
掌握 RNN 与 LSTM 模型结构何以解忧,唯有..4 小时前
Python包管理工具pip:从入门到精通金銀銅鐵4 小时前
用 Tkinter 实现简单的猜数字游戏copyer_xyf4 小时前
Python 模块与包的导入导出_1_74 小时前
SQL Server 磁盘满了 收缩日志ice8130331815 小时前
【Python】Matplotlib折线图绘制copyer_xyf5 小时前
Python venv 虚拟环境basketball6165 小时前
Redis基础:1. Redis介绍