因此,在我创建的使用自定义元素的库中,您显然需要在CustomElementsRegistry
实例化它之前定义类。
截至目前,这正在通过装饰器解决:
class Component extends HTMLElement {
static register (componentName) {
return component => {
window.customElements.define(componentName, component);
return component;
}
}
}
@Component.register('my-element')
class MyElement extends Component { }
document.body.appendChild(new MyElement());
这可行,但是,我想在类的实例化时自动注册自定义元素(这样作者就不必将装饰器添加到他们编写的每个组件中)。这可以通过Proxy
.
但是,我的问题是,当我尝试在构造函数上使用 Proxy 并尝试返回目标实例时,我仍然得到Illegal Constructor
,就好像该元素从未在注册表中定义过一样。
这显然与我在代理内部实例化类的方式有关,但我不确定如何做到这一点。我的代码如下:
请在最新的 Chrome 中运行:
class Component extends HTMLElement {
static get componentName () {
return this.name.replace(/[A-Z]/g, char => `-${ char.toLowerCase() }`).substring(1);
}
}
const ProxiedComponent = new Proxy(Component, {
construct (target, args, extender) {
const { componentName } = extender;
if (!window.customElements.get(componentName)) {
window.customElements.define(componentName, extender);
}
return new target(); // culprit
}
});
class MyElement extends ProxiedComponent { }
document.body.appendChild(new MyElement());
MyElement
我怎样才能继续代理内部的继承链,而不会丢失我正在实例化类以使其不会引发Illegal Constructor
异常这一事实的上下文?