首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vanilla JavaScript自定义元素TypeError

Vanilla JavaScript自定义元素TypeError
EN

Stack Overflow用户
提问于 2018-09-27 08:42:36
回答 1查看 71关注 0票数 1

我的问题是关于为自定义元素扩展HTMLElement。

代码语言:javascript
复制
class Foo extends HTMLElement { ... }

class Bar extends Foo { ... }

class FooBar extends Bar { ... }

它们中的每一个都在构造函数中调用super()。

当我用Bar定义一个自定义元素时,我没有得到任何错误

代码语言:javascript
复制
customElements.define( 'custom-tag', Bar );
or
customElements.define( 'custom-tag', class Bar extends Foo { ... } );

我正在尝试使用FooBar类定义一个自定义元素。

代码语言:javascript
复制
customElements.define( 'other-custom-tag', FooBar );
or
customElements.define( 'other-custom-tag', class FooBar extends Bar { ... } );

但我得到了

代码语言:javascript
复制
Uncaught TypeError: Failed to execute 'define' on 'CustomElementRegistry':
The provided value cannot be converted to a sequence.

通过Mozilla文档

https://developer.mozilla.org/en-US/docs/Web/API/CustomElementRegistry/define

代码语言:javascript
复制
TypeError   The referenced constructor is not a constructor.

我找不到任何与这个问题相关的东西...

EN

回答 1

Stack Overflow用户

发布于 2021-02-16 17:32:24

问题很可能是static get observedAttributes() -在我的例子中,我犯了一个愚蠢的拼写错误,在一个数组上使用了push,该数组返回新数组元素的计数,而不是数组本身(替换为concat,效果很好)。

换句话说,只要确保静态getter返回一个数组,就可以了

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52527849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档