Custom Elements API 允许开发者定义自定义 HTML 标签并赋予其行为与结构,通过 customElements.define() 注册,支持自主元素(如 <my-button>)和基于原生元素扩展的内置元素(如 <button is="fancy-button">),结合生命周期回调(connectedCallback、attributeChangedCallback 等)实现组件逻辑控制,配合 Shadow DOM 可达成样式隔离,适用于构建高复用、轻量级、原生封装的 UI 组件库。

Custom Elements API 是 Web Components 的核心部分之一,它允许开发者定义自己的 HTML 标签,并赋予这些标签自定义的行为和结构。通过 JavaScript 来注册新的元素类型,你可以创建可复用、封装良好的组件,直接在 HTML 中使用,无需依赖框架。
Custom Elements 让你能够创建全新的 HTML 元素,比如 <my-button> 或 <user-card>。这些元素可以像原生标签一样被使用,同时拥有自己的逻辑、样式和生命周期。
浏览器通过 customElements.define() 方法来注册一个自定义元素,该方法接收两个参数:元素名称(必须包含短横线)和一个继承自 HTMLElement 的类。
示例:class MyButton extends HTMLElement {
constructor() {
super();
this.textContent = '点击我';
this.style.padding = '10px';
this.style.background = '#007bff';
this.style.color = 'white';
this.style.borderRadius = '4px';
this.addEventListener('click', () => {
alert('按钮被点击!');
});
}
}
customElements.define('my-button', MyButton);
之后就可以在 HTML 中使用:
立即学习“Java免费学习笔记(深入)”;
<my-button></my-button>
Custom Elements 分为两种类型:自主自定义元素(Autonomous Custom Elements)和自定义内置元素(Customized Built-in Elements)。
class FancyButton extends HTMLButtonElement {
connectedCallback() {
this.style.fontSize = '18px';
this.style.background = 'linear-gradient(to right, #ff7e5f, #feb47b)';
}
}
customElements.define('fancy-button', FancyButton, { extends: 'button' });
使用时需写成:
<button is="fancy-button">渐变按钮</button>
自定义元素类中可以定义多个生命周期钩子,用于控制组件在不同阶段的行为:
class UserCard extends HTMLElement {
static get observedAttributes() {
return ['name', 'role'];
}
attributeChangedCallback(name, oldValue, newValue) {
if (name === 'name') {
this.innerHTML = `姓名:${newValue}`;
}
}
}
customElements.define('user-card', UserCard);
此时修改 name 属性会触发更新:
<user-card name="张三"></user-card>
使用 Custom Elements 可以构建高度封装的组件库,尤其适合设计系统或跨项目复用 UI 模块。
基本上就这些。Custom Elements 提供了原生级别的组件化能力,不依赖框架也能写出结构清晰、易于维护的前端代码。虽然生态上不如 React 或 Vue 丰富,但在轻量级场景或追求性能时非常有价值。
以上就是JavaScriptWeb组件_CustomElementsAPI的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号