我有一个从构造函数返回代理的类。当我尝试将此类的实例存储在 IndexedDB 中或使用 发送对象window.postMessage()
时,我收到一条错误消息,指出无法克隆该对象。结构化克隆算法似乎无法处理代理对象。
以下代码演示了该错误:
class MyClass {
constructor() {
return new Proxy(this, {
set(target, prop, val, receiver) {
console.log(`"${prop}" was set to "${val}"`);
return Reflect.set(target, prop, val, receiver);
}
});
}
}
const obj = new MyClass;
try {
window.postMessage(obj,'*');
} catch(err) {
console.error(err);
}
任何人都可以建议解决此问题的方法吗?我看到了两个潜在的解决方案,但我不知道如何实现它们:
不要从构造函数返回代理,而是以某种方式在类声明中维护代理功能。
更改 Proxy 实例,使其与结构化克隆算法一起使用。
编辑:以下更简单的代码还演示了结构化克隆错误:
const p = new Proxy({}, {});
window.postMessage(p, '*');