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

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

javascript 复制代码
const obj = {};
let _data = "这是一些数据";
Object.defineProperty(obj, "data", {
  get() {
    console.log("读取data的操作被拦截了");
    return _data;
  },
});
console.log(obj.data);

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

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

javascript 复制代码
const obj = {
};
const p = new Proxy(obj, {
  get(obj, prop) {
    console.log(`${prop}的读取操作被拦截了`);
    return obj[prop];
  },
});
console.log(p.data);
console.log(p.name);

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

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

javascript 复制代码
const obj = {
    name:'syt',
    age:4
};
const handler = {
  get(target, prop) {
    console.log(`${prop}的读取操作被拦截了`);
    return target[prop];  // target是另一个对象
  },
  set(target, prop, value) {
    console.log(`${prop}的设置操作被拦截了`);
    target[prop] = value;  // target是另一个对象
    return true;
  }
};

// 手动实现类似Proxy的功能
function createProxy(target, handler) {
  const proxy = {};
  Object.keys(target).forEach(key => {
    Object.defineProperty(proxy, key, {
      get() {
        return handler.get(target, key);  // 这里不会递归
      },
      set(value) {
        handler.set(target, key, value);
      }
    });
  });
  return proxy;
}

const p = createProxy(obj,handler);
console.log(p.name)
p.age=18

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

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

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

相关推荐
开开心心就好8 小时前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender
爱喝白开水a8 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied8 小时前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌418 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
3GPP仿真实验室9 小时前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
devmoon9 小时前
在 Polkadot 上部署独立区块链Paseo 测试网实战部署指南
开发语言·安全·区块链·polkadot·erc-20·测试网·独立链
lili-felicity9 小时前
CANN流水线并行推理与资源调度优化
开发语言·人工智能
沐知全栈开发9 小时前
CSS3 边框:全面解析与实战技巧
开发语言
island13149 小时前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络
曹牧9 小时前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言