news 2026/4/16 14:41:54

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/4/16 13:29:38

Liquibase动态删除表外键依赖

这是一个用于 Liquibase 的 SQL 脚本,它的核心功能是动态查找并删除指向某个特定表字段的所有外键约束。它通常用在数据库重构中,当你需要删除一个有外键引用的表或字段时,必须先解除这些依赖。 下面我将对脚本进行逐行详解,并举例…

作者头像 李华
网站建设 2026/4/16 13:30:32

12、构建Python应用与zc.buildout工具实践

构建Python应用与zc.buildout工具实践 1. 应用基础功能与数据库交互 在应用开发中,有两个全局函数用于与数据库交互: - get_entries :返回可过滤的条目。 - create_entry :添加一个条目。 当未找到条目时,生成器为空,示例代码如下: >>> entries = g…

作者头像 李华
网站建设 2026/4/16 13:31:18

基于django的协同过滤算法音乐推荐播放器

🍅 作者主页:Selina .a 🍅 简介:Java领域优质创作者🏆、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行交流合作。 主要内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据…

作者头像 李华
网站建设 2026/4/16 1:10:24

19、测试驱动开发:nose、py.test、Fakes、Mocks与文档驱动开发

测试驱动开发:nose、py.test、Fakes、Mocks与文档驱动开发 1. nose测试工具 1.1 安装 nose是一个具有强大发现功能的测试运行器,可使用 easy_install 进行安装: $ easy_install nose安装过程中会搜索相关资源并处理依赖: Searching for nose Reading http://pypi.…

作者头像 李华
网站建设 2026/4/16 11:00:13

WebRTC 架构概览(整体框架篇)

WebRTC 架构概览(整体框架篇) 本文是 WebRTC 系列专栏的第二篇,将深入剖析 WebRTC 的整体架构,包括浏览器中的实现架构、API 体系、信令流程以及底层媒体引擎 libwebrtc 的结构。 目录 WebRTC 在浏览器中的架构API 体系详解WebRT…

作者头像 李华
网站建设 2026/4/15 13:10:53

写一个最简单的 WebRTC Demo(实操篇)

写一个最简单的 WebRTC Demo(实操篇) 本文是 WebRTC 系列专栏的第三篇,我们将动手实践,从零开始构建一个完整的 WebRTC 音视频通话 Demo。通过这个实战项目,你将深入理解 WebRTC 的工作流程。 目录 项目概述获取摄像头…

作者头像 李华