当前位置: 首页 > wzjs >正文

自己的电脑做网站当服务器使用东莞高端品牌网站建设价格

自己的电脑做网站当服务器使用,东莞高端品牌网站建设价格,wordpress防止采集,佛山关键词自动排名在现代浏览器中,通过 class 继承 HTMLElement 可以轻松创建原生 Web Components(自定义元素),并能享受与普通 HTML 元素同等的语义和性能优势。下面将从核心概念、生命周期方法、Shadow DOM、表单关联、自定义属性、以及与 Vue 3 …

在现代浏览器中,通过 class 继承 HTMLElement 可以轻松创建原生 Web Components(自定义元素),并能享受与普通 HTML 元素同等的语义和性能优势。下面将从核心概念、生命周期方法、Shadow DOM、表单关联、自定义属性、以及与 Vue 3 的集成等方面,详细说明如何使用

概览

继承 HTMLElement 起点于 ECMAScript 的 extends 关键字,它用于在类声明或表达式中创建子类。自定义元素本质上是一个继承自 HTMLElement(或某个内置元素接口)的类,注册后即可像普通标签一样使用,同时可在内部封装状态、事件和样式

JavaScript 中的 extends 与 HTMLElement 接口

  1. extends 关键字

extends 用于创建子类,保证子类实例具有父类的属性和方法;必须在子类构造函数中首先调用 super()

  1. HTMLElement 接口

HTMLElement 是所有 HTML 元素的基础接口,提供访问 DOM 属性、事件和方法,如 id、innerHTML、click() 等

  1. 定义自定义元素

自主式(Autonomous) vs. 内置扩展(Customized built-in),自主式元素:直接继承 HTMLElement,需从零实现行为,内置扩展元素:继承特定接口(如 HTMLParagraphElement),在保留原有行为基础上添加新功能;但 Safari 尚不支持此模式
最小示例

class MyPopup extends HTMLElement {constructor() {super(); // 必须调用// 初始状态或事件绑定}connectedCallback() {this.textContent = 'Hello Web Component';}
}
customElements.define('my-popup', MyPopup);

浏览器解析到 时,会实例化该类并调用相应生命周期方法

生命周期回调

自定义元素提供多种回调,可在不同阶段执行逻辑

  • connectedCallback():元素插入文档时触发,推荐在此完成 DOM 渲染和事件绑定
  • disconnectedCallback():元素从文档移除时触发,用于清理资源。
  • adoptedCallback():元素被移动到新文档时触发。
  • attributeChangedCallback(name, oldV, newV):监听属性变化,需通过静态 observedAttributes 指定监控列表

Shadow DOM 与样式封装

  • 通过 this.attachShadow({ mode: ‘open’ }) 创建 Shadow 根,实现样式和 DOM 的隔离
constructor() {super();const shadow = this.attachShadow({ mode: 'open' });shadow.innerHTML = `<style>p { color: red; }</style><p><slot></slot></p>`;
}
  • 插槽 支持内容投影。
  • Shadow DOM 规范详情可参阅 MDN «Using shadow DOM»

表单关联(Form-associated)

class MyCheckbox extends HTMLElement {static formAssociated = true;  // 启用表单关联constructor() {super();this._internals = this.attachInternals(); // 获取 ElementInternals}// ...实现 name、value、checked 等属性
}
customElements.define('my-checkbox', MyCheckbox);
  • attachInternals() 返回 ElementInternals,用于控制表单行为和 ARIA 信息

TypeScript 中扩展 HTMLElement

declare global {interface HTMLElementTagNameMap {'my-element': MyElement;}
}
class MyElement extends HTMLElement {foo!: string; // 自定义属性
}
customElements.define('my-element', MyElement);

在 Vue 3 中定义原生 Custom Elements

import { defineCustomElement } from 'vue';
import MyVueComp from './MyVueComp.ce.vue';const MyVueElement = defineCustomElement({...MyVueComp,styles: ['/* inlined CSS */']
});
customElements.define('my-vue-element', MyVueElement);

综合示例

<!DOCTYPE html>
<html>
<head><script type="module" src="my-element.js"></script>
</head>
<body><my-popup></my-popup><my-vue-element some-prop="value"></my-vue-element>
</body>
</html>JS----
// my-element.js
class MyPopup extends HTMLElement {constructor() {super();
//    mode: 'open' 允许外部脚本访问 element.shadowRootthis.attachShadow({ mode: 'open' });}connectedCallback() {this.shadowRoot.innerHTML = `<p>自定义弹窗内容</p>`;}
}
customElements.define('my-popup', MyPopup);

生命周期

class MyEl extends HTMLElement {static get observedAttributes() { return ['foo']; }constructor() {super(); // 必须调用// 请勿在此访问 DOM}connectedCallback() {// 渲染 UI、绑定事件}attributeChangedCallback(name, oldVal, newVal) {// 响应属性变化}disconnectedCallback() {// 清理事件、定时器}
}
customElements.define('my-el', MyEl);

Shadow DOM是什么?

Shadow DOM是Web Components标准的一部分,它允许开发者将一个隐藏的、独立的DOM树附加到一个元素上。这就像是在一个主文档的DOM中创建了一个“影子”DOM,这个“影子”DOM有自己的结构和样式,与主文档的DOM相互隔离

隔离性

  1. 样式隔离:Shadow DOM中的样式不会泄漏到主文档中,主文档中的样式也不会影响Shadow DOM内部的元素。例如,如果在主文档中有一个全局的p标签样式(如p { color: blue; }),在Shadow DOM内部的p标签不会受到这个样式的影响,除非在Shadow DOM内部显式地引用了外部样式。
  2. 结构隔离:Shadow DOM内部的元素结构对于外部是隐藏的。这意味着外部JavaScript代码不能直接访问Shadow DOM内部的元素,就像它们被封装在一个黑盒中一样。例如,在一个自定义元素的Shadow DOM中,有一个元素,外部脚本不能直接通过document.querySelector(‘input’)来获取这个输入元素,因为它被封装在Shadow DOM中
class MyShadowDOMElement extends HTMLElement {constructor() {super();// 创建影子DOMconst shadow = this.attachShadow({mode: 'open'});// 创建内部的HTML元素const div = document.createElement('div');div.textContent = 'Content inside Shadow DOM';// 创建样式const style = document.createElement('style');style.textContent = 'div { color: blue; }';// 将样式和元素添加到影子DOM中shadow.appendChild(style);shadow.appendChild(div);}
}
customElements.define('my - shadow - dom - element', MyShadowDOMElement);

template 模版、插槽

模版<template id="card-tpl"><style>.card { border:1px solid #ccc; padding:1em; border-radius:4px; }::slotted(h2) { margin-top:0; }</style><div class="card"><header><slot name="header">默认标题2</slot></header><section><slot></slot></section><footer><slot name="footer">默认页脚</slot></footer></div></template>
js----
class MyCard extends HTMLElement {constructor() {super();const tpl = document.getElementById('card-tpl').content;this.attachShadow({mode:'open'}).appendChild(tpl.cloneNode(true));}}customElements.define('my-card', MyCard);
使用---
<my-card><h2 slot="header">卡片标题</h2><p>这里是卡片主体内容。</p><small slot="footer">© 2025</small></my-card>

文章转载自:

http://jEkImv7U.Lkgqb.cn
http://eFLmektr.Lkgqb.cn
http://nNegd45h.Lkgqb.cn
http://MCux5Sq8.Lkgqb.cn
http://Ay6KezNk.Lkgqb.cn
http://GSTarKKU.Lkgqb.cn
http://Omt1oaTW.Lkgqb.cn
http://3qyWHaj0.Lkgqb.cn
http://uoLEQIQp.Lkgqb.cn
http://N1rmMgox.Lkgqb.cn
http://2fhOFNEu.Lkgqb.cn
http://JYuw5p6O.Lkgqb.cn
http://PYnAUNKA.Lkgqb.cn
http://ja3Yl6QN.Lkgqb.cn
http://Qu4aZSb6.Lkgqb.cn
http://YCxfTeBT.Lkgqb.cn
http://I9xZkijQ.Lkgqb.cn
http://NuTJ3T3w.Lkgqb.cn
http://42zeFp3z.Lkgqb.cn
http://qwyNIpMz.Lkgqb.cn
http://9Y6EcPki.Lkgqb.cn
http://PcSElumO.Lkgqb.cn
http://G6V4NRXa.Lkgqb.cn
http://iIuySV8P.Lkgqb.cn
http://4yR0LiT8.Lkgqb.cn
http://70g0Iuju.Lkgqb.cn
http://qYvKhMW9.Lkgqb.cn
http://cheA9syJ.Lkgqb.cn
http://SLoALEUu.Lkgqb.cn
http://PTEVbjr8.Lkgqb.cn
http://www.dtcms.com/wzjs/705942.html

相关文章:

  • 奥联网站建设怎么自己做免费网站
  • 网站开发要什么软件有哪些网站 流量 不够用
  • 网站建设贵苏州网站开发费用详情
  • 定制手机微网站网站宣传视频
  • 做好三步网站改版工具不降权 无忧老师制作公司网站怎么做
  • 青岛圭谷网站建设公司怎么样网站排名优化外包公司
  • 大型网站服务器架构高端设计网站
  • 网站怎样才有流量各大网站做推广广告
  • 站长之家的作用重庆万州网站建设找谁
  • 管理手机网站首页肥城网站制作
  • 企业门户网站模板分享成都网络营销精英
  • 网站左侧广告代码安庆市重点工程建设局网站
  • 做网站用虚拟主机还是服务器wordpress同学录
  • 丹阳网站建设要多少钱大兴黄村网站建设
  • 成都科盛兴网站建设有限公司description+wordpress
  • 设计素材网站图案免费wordpress上的博客
  • 网站模板文章资讯浙江建设人才网
  • 做网站和编程序网站分享组件
  • 建设一个收入支出持平的网站河北省邢台市建设工程网站
  • 做网站的软件工程师wordpress局域网404
  • storyset自定义插画网站网站建设服
  • 什么网站可以免费做视频写安卓软件用什么工具
  • 台州电子商务网站开发360网站图标怎么做的
  • 域名网站空间网站程序上传教程
  • 无忧网站网站的字体
  • wordpress网站地图提交湖南人事考试网
  • 田园综合体建设网站wordpress加载网页
  • 淮南市潘集区信息建设网站毕业设计除了网站还可以做啥
  • 用asp.net制作一个网站需要多久沈阳网站建设管理
  • 建网站空间都有什么平台app外包网