信息发布→ 登录 注册 退出

j*ascript的shadow dom是什么_它如何封装样式?

发布时间:2025-12-14

点击量:
Shadow DOM 是浏览器原生的 DOM 封装机制,通过 attachShadow 创建独立子树实现样式局部化与 DOM 隔离;支持天然隔离、::slotted() 穿透和 :host 控制,继承属性与全局样式仍可透入,open 模式下 JS 可访问但样式封装由浏览器保障。

javascript的shadow dom是什么_它如何封装样式?

Shadow DOM 是浏览器原生支持的一种 DOM 封装机制,它让组件的结构、样式和行为与主文档(light DOM)相互隔离,实现真正意义上的“样式局部化”和“DOM 隔离”。它不是 J*aScript 的语法特性,而是 Web Components 规范的一部分,通过 J*aScript API 创建和操作。

Shadow DOM 的核心:独立的 DOM 子树

调用 element.attachShadow({ mode: 'open' }) 后,该元素就拥有了一个 shadow root,它是一个独立的 DOM 根节点。所有追加到 shadow root 中的 HTML 结构(比如 divstyleslot)都只在这个子树内生效,外部 CSS 选中器默认无法穿透进来,内部样式也不会泄露出去。

例如:

const host = document.querySelector('#my-card');
const shadow = host.attachShadow({ mode: 'open' });
shadow.innerHTML = `
  <style>
    h2 { color: #2c3e50; margin: 0; }
    .content { font-size: 14px; }
  </style>
  <h2>用户卡片</h2>
  <div class="content"><slot></slot></div>
`;

这段 <style></style> 只作用于 shadow 内部的 h2.content,不会影响页面其他地方的同名标签或类名。

美图AI开放平台 美图AI开放平台

美图推出的AI人脸图像处理平台

美图AI开放平台 111 查看详情 美图AI开放平台

样式封装的三种关键方式

  • 天然隔离:普通 CSS 选择器(如 .btndiv p)在 shadow root 外写,不会匹配 shadow 内元素;反过来,shadow 内的样式也不会影响 light DOM。
  • ::slotted() 有限穿透:只能用于选择被 <slot></slot> 投影进来的外部节点,且仅支持简单选择器(不能带后代/子代组合器),例如 ::slotted(.title) 可以给传入 slot 的 <h3 class="title"></h3> 加样式,但 ::slotted(div .title) 无效。
  • :host 和 :host-context 提供宿主控制:host 匹配 shadow 宿主元素自身(即调用 attachShadow 的那个元素),:host(.active) 表示只有宿主有 active 类时才生效;:host-context(body.dark) 则可响应外部上下文(如整个页面切暗色主题)。

注意边界:哪些情况会打破封装?

封装不是绝对的“铁壁”:

  • CSS 继承属性仍会透入:比如 colorfont-familyline-height 等可继承属性,若 shadow 内没显式设置,会从宿主元素继承 —— 这是设计使然,方便主题统一。
  • 全局样式(如 @font-face、@keyframes)依然有效:它们作用于整个 document,shadow 内可直接使用定义好的字体或动画名。
  • J*aScript 仍可跨边界访问:如果 shadow root 是 open 模式,外部可通过 host.shadowRoot 拿到并操作内部节点(所以逻辑封装要靠自觉,样式封装才靠机制)。

基本上就这些。Shadow DOM 的样式封装不依赖构建工具或 BEM 命名,是浏览器级保障,适合构建高复用、低冲突的 UI 组件。

以上就是j*ascript的shadow dom是什么_它如何封装样式?的详细内容,更多请关注其它相关文章!


相关文章: J*aScript中管理异步API调用:确保操作顺序与数据一致性  QQ邮箱网页版邮箱入口 QQ邮箱官方登录平台  J*a 递归快速排序中静态变量的状态管理与陷阱  QQ官网正版登录链接 QQ在线登录入口最新  优化Django表单:提交验证失败后保留用户输入  离线运行Go语言之旅:本地部署与GOPATH配置指南  如何在Promise链中有效终止错误处理后的执行  jQuery Mask 插件中实现电话号码固定前导零的教程  在Socket.IO连接中实现Access Token自动更新与动态重连  CSS子选择器:如何区分并样式化嵌套列表的子层级  可靠CSGO开箱平台解析 CSGO开箱网合集  Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  Composer中的^和~符号代表什么_精通Composer版本号语义化约束  J*a里如何使用N*igableMap进行导航操作_可导航Map操作技巧解析  Discord Slash 命令响应超时问题的异步解决方案  J*a ArrayList索引越界异常:动态构建列数据的高效策略  Windows10怎么开启存储感知 Windows10系统设置自动清理临时文件释放C盘空间【教程】  铃兰之剑为这和平的世界希里技能组及加点推荐  Excel Power Pivot如何处理XML数据源 构建高级数据模型  生成rdflib自定义SPARQL函数:参数匹配与实践指南  php源码怎么在电脑上测试_电脑测试php源码方法步骤【教程】  AO3最新官网入口公告_2025AO3镜像站实时查询方法  如何在J*a中实现统一对象行为接口_项目大型化时的接口规范化  KFC游戏互动怎么赢取优惠券_KFC线上游戏活动参与与优惠代码赢取教程  拼多多购物车商品数量无法修改如何处理 拼多多购物车操作优化方法  J*aScript实现动态背景色下的文本与按钮颜色自适应调整  微信商城在哪里打开【步骤】  J*a应用集成GitHub CLI与API认证指南  将PCM16音频数据转换为W*并编码为Base64教程  PHP面向对象编程中避免重复创建PDO数据库连接的最佳实践  AO3中文官网链接_AO3网页版稳定镜像站  J*aScript map 迭代中检测空数组元素的有效方法  利用Bokeh CustomJS动态控制DataTable列可见性  Go Martini框架:动态服务解码后的图片内容  PDF文件体积过大处理_PDF压缩技巧详解  KFC套餐升级怎么获取优惠代码_KFC套餐升级活动与优惠代码获取方法  《北京人工智能产业白皮书(2025)》发布:全年核心产值预计突破 4500 亿元  Go语言中动态执行代码字符串的策略与实践  实现分段式页面滚动导航:CSS与J*aScript教程  蛙漫漫画官网在线入口 蛙漫全本漫画免费阅读平台  在Pyomo中实现基于变量的条件约束:Big-M方法详解  漫蛙2在线漫画入口 漫蛙正版漫画网页版直达  怎么在浏览器上运行HTML文件_浏览器运行HTML文件技巧【技巧】  PHP文件上传至S3:策略、考量与避免本地存储的挑战  如何在 Excel Online 和 Google 表格中更改日期格式  Walmart退货API集成指南:PHP cURL实现与常见问题解析  PHP中高效并行检查多链接状态的教程  Python多版本共存与虚拟环境管理深度指南  BetterDiscord插件中安全更新用户简介的实践指南  解决Flask中Quill编辑器内容提交失败及TypeError的指南 

在线客服
服务热线

服务热线

4008988990

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!