下满是示例代码:
function createProxy(value = 0) { return new Proxy( {}, // 使用空对象作为目标对象 { get(target, prop) { if (prop === Symbol.toPrimitive) { return () => value; // 返回当前值 } return createProxy(value + Number(prop)); // 递归创建代理 } } ); } const add = createProxy(); console.log(add[23][33] + 2); console.log(add + 2);
目标对象:在 new Proxy 中,第一个参数是目标对象。这里我们使用一个空对象 {} 作为目标对象,因为我们的主要目的是通过 get 陷阱来处理属性访问。
如果访问的属性是 Symbol.toPrimitive,我们返回一个函数,该函数返回当前的 value。这是为了在执行加法操作时,能够将代理对象转换为原始值。否则,我们递归地创建一个新的代理对象,并将 value 加上访问的属性值(转换为数字)。网友回复