news 2026/6/23 7:20:52

Object.defineProperty和Proxy实现拦截的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Object.defineProperty和Proxy实现拦截的区别

1.Object.definedProperty的实现拦截必须得声明一个额外的变量,例如下面这样

constobj={};let_data="这是一些数据";Object.defineProperty(obj,"data",{get(){console.log("读取data的操作被拦截了");return_data;},});console.log(obj.data);

但是如果你这么写,就会报错,栈溢出,因为递归调用了

2.使用proxy,可以定义空对象,里面不写属性值,他不会报栈溢出的原因也是因为没有递归调用,根本原因是因为拦截器返回的不是它本身,而是obj的属性值

constobj={};constp=newProxy(obj,{get(obj,prop){console.log(`${prop}的读取操作被拦截了`);returnobj[prop];},});console.log(p.data);console.log(p.name);


3.如果你这么写,同样会报栈溢出

5.如果想要实现和proxy类似功能,可以这样写

constobj={name:'syt',age:4};consthandler={get(target,prop){console.log(`${prop}的读取操作被拦截了`);returntarget[prop];// target是另一个对象},set(target,prop,value){console.log(`${prop}的设置操作被拦截了`);target[prop]=value;// target是另一个对象returntrue;}};// 手动实现类似Proxy的功能functioncreateProxy(target,handler){constproxy={};Object.keys(target).forEach(key=>{Object.defineProperty(proxy,key,{get(){returnhandler.get(target,key);// 这里不会递归},set(value){handler.set(target,key,value);}});});returnproxy;}constp=createProxy(obj,handler);console.log(p.name)p.age=18


6.但是,这种写法,也是必须的在obj中写上所有的key,才可以拦截到,如果你不写的话就拦截不到

7.如果使用proxy的话,就可以不用定义key,写一个空的对象就可以


当然这两个只是拿get和set来做对比,简单记录下

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 16:22:12

若依物联网

物联网平台 - Thinglinks-iot ## 🌟 项目简介 一个功能完备、高可扩展的物联网平台,提供完整的设备接入、管理和数据处理解决方案。支持多种网络协议,具备强大的消息解析和实时告警能力,帮助企业快速构建物联网应用。 该项目现已纳…

作者头像 李华
网站建设 2026/6/23 18:04:48

PSEN1抗体:如何揭示阿尔茨海默病致病机制与治疗新靶点?

一、PSEN1基因为何成为神经退行性疾病研究的关键靶点? PSEN1(早老素1)基因位于人类14号染色体q24.2区域,全长87kb,包含14个外显子,编码由467个氨基酸组成的跨膜蛋白,分子量约为53kD。该基因在进…

作者头像 李华
网站建设 2026/6/22 8:47:46

Docker Engine 升级指南:保障容器安全的关键步骤

无论是为了获得新功能、性能优化,还是更关键的——为了修复重大的安全漏洞(如 runc 漏洞 CVE-2024-21626),定期升级 Docker Engine 都是容器基础设施运维中的一项重要任务。 本篇文章将为您提供一个通用的升级流程,确保…

作者头像 李华
网站建设 2026/6/23 8:55:15

7、Python高级语法:描述器、属性与元编程实战

Python高级语法:描述器、属性与元编程实战 1. Python中的私有属性与名称修饰 许多C++和Java程序员初涉Python时,会惊讶于Python没有 private 关键字。Python中最接近的概念是“名称修饰”(name mangling)。每当属性以 __ 为前缀时,解释器会动态重命名该属性。示例如…

作者头像 李华
网站建设 2026/6/23 11:51:58

【开题答辩全过程】以 基于java技术的校园一卡通系统的设计与实现为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华