新闻中心
使用Shadow DOM实现样式封装
Shadow DOM是Web Components标准的一部分,通过创建独立的DOM树实现样式和结构的隔离。使用Element.attachShadow()方法可将Shadow DOM附加到元素上,并通过mode属性控制访问权限。示例中定义了MyComponent类,在constructor中创建Shadow Root并注入HTML与CSS,确保内部样式不泄漏、外部样式不侵入。其优势包括样式隔离、避免命名冲突、提升组件复用性和结构清晰性。需注意:无法直接通过document.querySelector()访问内部元素,继承样式可能需手动传递,部分伪元素不适用。掌握Shadow DOM有助于构建高内聚、可维护的前端组件。

在现代Web开发中,组件化是构建可维护应用的关键。使用Shadow DOM可以有效实现样式封装,避免全局样式污染,确保组件内部样式与外部隔离。
什么是Shadow DOM
Shadow DOM是Web Components标准的一部分,允许开发者为元素创建一个独立的DOM树。这个树与主文档的DOM隔离,包括样式和脚本。
通过Shadow DOM,组件内的CSS不会影响页面其他部分,外部样式也不会意外修改组件内部结构。
如何创建带有样式封装的Shadow DOM
使用Element.attachShadow()方法可以将Shadow DOM附加到一个元素上。设置mode: 'closed'或'open'来控制外部访问能力。
以下是一个简单示例:
class MyComponent extends HTMLElement {
constructor() {
super();
// 创建Shadow Root
this.shadow = this.attachShadow({ mode: 'open' });
// 添加HTML结构
this.shadow.innerHTML = `
<sty
le>
.container {
padding: 16px;
background-color: #f0f0f0;
border-radius: 8px;
font-family: sans-serif;
}
p {
color: #333;
margin: 0;
}
</style>
<div class="container">
<p>这是一个封装样式的组件</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/xiazai/code/8666">
<img src="https://img.php.cn/upload/webcode/000/000/018/175618440397172.png" alt="ReportPlus数据报表中心小程序">
</a>
<div class="aritcle_card_info">
<a href="/xiazai/code/8666">ReportPlus数据报表中心小程序</a>
<p>ReportPlust意在打造一套精美的数据报表模板,里面高度封装日历组件、表格组件、排行榜组件、条形进度条组件、文本块组件以及ucharts的多个图表组件,用户只需要按照虚拟数据的格式,传特定数据即可方便、快捷地打造出属于自己的报表页面。该小程序主要使用了ucharts和wyb-table两插件实现的数据报表功能。 特点使用的是uni-app中最受欢迎的图表uCharts插件完成图表展示,该插件</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="ReportPlus数据报表中心小程序">
<span>1</span>
</div>
</div>
<a href="/xiazai/code/8666" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="ReportPlus数据报表中心小程序">
</a>
</div>
</div>
`;
}
}
// 定义自定义元素
customElements.define('my-component', MyComponent);
在页面中使用:
<my-component></my-component>
此时,.container和p的样式仅作用于Shadow DOM内部,不受外部CSS影响,也不会泄漏出去。
Shadow DOM样式封装的优势
- 样式隔离:组件内样式不会被全局样式覆盖,也不影响其他组件
- 避免命名冲突:无需使用BEM等复杂命名规范
- 提升可复用性:组件可在不同项目中直接使用,无需担心样式兼容问题
- 更清晰的结构:HTML、CSS、J*aScript可封装在同一组件类中
注意事项
虽然Shadow DOM提供了强大的封装能力,但也有一些细节需要注意:
- 外部无法直接通过document.querySelector()选中Shadow内部元素,需通过shadowRoot访问
- 继承样式(如font-family)可能不会自动穿透,建议在Shadow根元素上显式传递
- 某些伪元素(如::backdrop)不适用于Shadow DOM内部
基本上就这些。使用Shadow DOM实现样式封装,能让你的Web组件真正“自包含”,是构建大型前端应用时值得掌握的技术。
以上就是使用Shadow DOM实现样式封装的详细内容,更多请关注php中文网其它相关文章!
# 不匹配
# 长沙那个培训seo
# 娄底网站建设案例展示会
# 跨境独立自建站营销推广
# 营销号推广面膜
# 关键词排名的公司有几家
# 名气大的灯饰网站建设
# 厦门网站建设怎么找客户
# 云浮网站推广有哪些方法
# SEO网站图片代码优化
# 徐州智能网站建设分类
# 相关文章
# 这是一个
# 多个
# 是一个
# php
# 的是
# 复用
# 自己的
# 中不
# 也不
# 前端应用
# ai
# 伪元素
# 前端
# html
# javascript
# css
# java
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
实现分段式页面滚动导航:CSS与J*aScript教程
J*a递归快速排序中静态变量的状态管理与陷阱
c++如何使用std::memory_order控制原子操作顺序_c++ C++11内存模型详解
马斯克:Optimus 人形机器人复数形式为 Optimi
知音漫客官网漫画下载_知音漫客网页版阅读记录
sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置
AO3镜像入口大全 AO3网页版内容访问全集
菜鸟取件码是什么怎么查 最全查询渠道汇总
React项目中导航栏Logo自适应布局:避免裁剪与布局溢出
反效果?《战地6》免费试玩开启后玩家数不升反降
LINUX的I/O重定向是什么_深入理解LINUX中 >、>> 与 < 的区别
如何在 Excel Online 和 Google 表格中更改日期格式
sublime怎么设置启动时打开的窗口_sublime会话管理与热退出
PHP中高效并行检查多链接状态的教程
ArrayList与LinkedList操作复杂度详解:遍历与修改
CSS布局中意外空白:解决padding-top导致的顶部间距问题
腾讯视频怎么使用多账号家庭管理_腾讯视频家庭多账号统一管理与权限分配教程
Go Martini框架:动态服务解码后的图片内容
UE5.7引擎表现爆炸优化无敌!5090跑4K稳定60FPS
漫蛙MANWA漫画主页官方入口 漫蛙漫画最新在线阅读地址
Yandex官网免登录入口_俄罗斯Yandex搜索引擎一键访问
J*aScript中向JSON对象添加新属性的正确姿势
神庙逃亡小游戏在线玩 神庙逃亡小游戏入口
谷歌浏览器怎么给标签页静音_Chrome标签静音快捷操作
消息称三星明年 2 月正式发布 HBM4,与 SK 海力士同台竞技
如何更改在 Excel 中打开超链接时的默认浏览器
J*aScript打印功能_j*ascript输出控制
如何在Promise链中有效终止错误处理后的执行
多闪网页版在线观看免费入口_多闪官网访问入口
如何在网页中实现特定地点的随机图片展示
微博网页版主页入口 微博官方网站免登录访问
必由学官方平台入口 必由学在线课堂登录地址
Win11怎么关闭快速启动_Win11彻底关机设置教程
生成rdflib自定义SPARQL函数:参数匹配与实践指南
包子漫画官方网站阅读入口-包子漫画在线漫画官网直达链接
MAC的“快捷指令”怎么同步到iPhone_MAC利用iCloud同步所有设备的自动化指令
一加Ace 6T实拍样张首次公布!李杰:主摄实力完全看齐4K档性能旗舰
c++20的std::jthread是什么_c++可中断线程与RAII式管理
AO3网页版合集入口 Archive of Our Own同人作品浏览指南
怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法
4399网页游戏电脑版全新入口 4399电脑端在线玩指南
Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】
Win11怎么开启卓越性能模式 Win11电源选项启用高性能释放硬件潜力【方法】
漫蛙漫画官方首页 漫蛙2漫画在线阅读入口
NVIDIA股价11月重挫12%:下月有望好转 但难回5万亿美元巅峰
C++如何实现一个装饰器模式_C++设计模式之动态地给对象添加额外职责
在J*a中如何使用Exception包装底层异常_异常包装与信息传递方法说明
动漫花园资源网使用步骤_动漫花园资源网下载流程
漫画星球免费下拉式入口 漫画星球免费漫画在线阅读网站
印象笔记怎样用批量导出备知识库_印象笔记用批量导出备知识库【备份方法】


2025-11-03
浏览次数:次
返回列表
le>
.container {
padding: 16px;
background-color: #f0f0f0;
border-radius: 8px;
font-family: sans-serif;
}
p {
color: #333;
margin: 0;
}
</style>
<div class="container">
<p>这是一个封装样式的组件</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/xiazai/code/8666">
<img src="https://img.php.cn/upload/webcode/000/000/018/175618440397172.png" alt="ReportPlus数据报表中心小程序">
</a>
<div class="aritcle_card_info">
<a href="/xiazai/code/8666">ReportPlus数据报表中心小程序</a>
<p>ReportPlust意在打造一套精美的数据报表模板,里面高度封装日历组件、表格组件、排行榜组件、条形进度条组件、文本块组件以及ucharts的多个图表组件,用户只需要按照虚拟数据的格式,传特定数据即可方便、快捷地打造出属于自己的报表页面。该小程序主要使用了ucharts和wyb-table两插件实现的数据报表功能。 特点使用的是uni-app中最受欢迎的图表uCharts插件完成图表展示,该插件</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="ReportPlus数据报表中心小程序">
<span>1</span>
</div>
</div>
<a href="/xiazai/code/8666" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="ReportPlus数据报表中心小程序">
</a>
</div>
</div>
`;
}
}
// 定义自定义元素
customElements.define('my-component', MyComponent);