Shadow DOM的理解
Shadow DOM的理解
Shadow DOM
是HTML
的一个规范,其允许在文档document
渲染时插入一颗DOM
元素子树,但是这棵子树不在主DOM
树中,Shadow DOM
如果按照英文翻译的话可以翻译为影子DOM
,是一种不属于主DOM
树的独立的结构。
描述
Web components
的一个重要属性是封装——可以将标记结构、样式和行为隐藏起来,并与页面上的其他代码相隔离,保证不同的部分不会混在一起,可使代码更加干净、整洁,在这里Shadow DOM
接口是关键所在,它可以将一个隐藏的、独立的DOM
附加到一个元素上,Shadow DOM
标准允许你为你自己的元素custom element
维护一组Shadow DOM
。
Shadow DOM
允许将隐藏的DOM
树附加到常规的DOM
树中,它以shadow root
节点为起始根节点,在这个根节点的下方,可以是任意元素,和普通的DOM
元素一样,另外还有一些Shadow DOM
特有的术语。
Shadow host
: 一个常规DOM
节点,Shadow DOM
会被附加到这个节点上。Shadow tree
:Shadow DOM
内部的DOM
树。Shadow boundary
:Shadow DOM
结束的地方,也是常规DOM
开始的地方。Shadow root
:Shadow tree
的根节点。
我们可以使用同样的方式来操作Shadow DOM
,就和操作常规DOM
一样——例如添加子节点、设置属性,以及为节点添加自己的样式(例如通过element.style
属性),或者为整个Shadow DOM
添加样式(例如在<style>
元素内添加样式),不同的是Shadow DOM
内部的元素始终不会影响到它外部的元素(除了:focus-within
),这就为封装提供了便利。
此外不管从哪个方面来看Shadow DOM
都不是一个新事物,在过去的很长一段时间里,浏览器用它来封装一些元素的内部结构,以一个有着默认播放控制按钮的<video>
元素为例,我们所能看到的只是一个<video>
标签,实际上,在它的Shadow DOM
中,包含来一系列的按钮和其他控制器。再举一个例子我们都知道像React
或Vue
这样的都有组件的概念,我们常用的<input>
、<audio>
、<video>
等这些元素,其实它也是以组件的形式存在的,即HTML Web Component
这些都有自己的Shadow DOM
,这些组件内部是由自身的一些HTML
标签组成的。
现代浏览器Firefox
、Chrome
、Opera
和Safari
等默认支持Shadow DOM
,基于Chromium
的新Edge
也支持Shadow DOM
,而旧Edge
未能撑到支持此特性,至于IE
浏览器嘛...
,兼容性方面可以查阅此处https://caniuse.com/?search=Shadow%20DOM
。
示例
<!DOCTYPE html>
<html>
<head>
<title>Shadow DOM</title>
<style>
.text{
color: blue; /* 设置字体颜色 */ /* 可以看出在外部定义的样式无法影响到影子内部元素样式 */
}
</style>
</head>
<body>
<div id="app">
<div class="shadow-cls"></div>
</div>
</body>
<script type="text/javascript">
(function(doc, win){
var shadowHost = doc.querySelector(".shadow-cls"); // 获取影子宿主shadow host
var shadowRoot = shadowHost.attachShadow({mode: "open"}); // 创建(附加)影子shadow root // open 表示可以通过页面内的 JavaScript 方法来获取 Shadow DOM
var style = doc.createElement("style"); // 创建style元素
style.textContent = `
.text{
font-style: italic;
}
`; // 影子内部样式
const template = `
<div>
<div class="text">Text</div>
</div>
`; // 模板 // 另外可以尝试 <template> 以及 <script text/template>
const container = doc.createElement("div"); // 创建容器
container.innerHTML = template; // 加入容器
shadowRoot.append(style, container); // 加入影子
})(document, window);
</script>
</html>
每日一题
https://github.com/WindrunnerMax/EveryDay
参考
https://segmentfault.com/a/1190000017970486
https://www.cnblogs.com/tugenhua0707/p/10545179.html
https://developer.mozilla.org/zh-CN/docs/Web/Web_Components/Using_shadow_DOM
Shadow DOM的理解的更多相关文章
- 理解Shadow DOM(一)
1. 什么是Shadow DOM? Shadow DOM 如果按照英文翻译的话可以理解为 影子DOM, 何为影子DOM呢?可以理解为一般情况下使用肉眼看不到的DOM结构,那如果一般情况下看不到的话,那 ...
- shadow dom
初识shadow dom 我们先看个input="range"的表现: what amazing ! 一个dom能表现出这么多样式嘛? 无论是初学者和老鸟都是不肯相信的,于是在好奇 ...
- Shadow DOM及自定义标签
参考链接:点我 一.什么是Shadow DOM Shadow DOM,直接翻译的话就是 影子 DOM,可以理解为潜藏在 DOM 结构中并且我们无法直接控制操纵的 DOM 结构.类似于下面这种结构 Sh ...
- 究竟什么是Shadow DOM?
shadow dom 是什么? 顾名思义,shadow dom直译的话就是影子dom,但我更愿把它理解为DOM中的DOM.因为他能够为Web组件中的 DOM和 CSS提供了封装,实际上是在浏览器渲染文 ...
- 【shadow dom入UI】web components思想如何应用于实际项目
回顾 经过昨天的优化处理([前端优化之拆分CSS]前端三剑客的分分合合),我们在UI一块做了几个关键动作: ① CSS入UI ② CSS作为组件的一个节点而存在,并且会被“格式化”,即选择器带id前缀 ...
- 封印术:shadow dom
置顶文章:<纯CSS打造银色MacBook Air(完整版)> 上一篇:<鼠标滚动插件smoovejs和wowjs> 作者主页:myvin 博主QQ:851399101(点击Q ...
- 使用shadow dom封装web组件
什么是shadow dom? 首先我们先来看看它长什么样子.在HTML5中,我们只用写如下简单的两行代码,就可以通过 <video> 标签来创建一个浏览器自带的视频播放器控件. <v ...
- shadow dom 隔离代码 封装
Shadow DOM是指浏览器的一种能力,它允许在文档(document)渲染时插入一棵DOM元素子树,但是这棵子树不在主DOM树中. Shadow DOM 解决了 DOM 树的封装问题. ...
- 纯CSS菜单样式,及其Shadow DOM,Json接口 实现
先声明,要看懂这篇博客要求你具备少量基础CSS知识, 当然如果你只是要用的话就随便了,不用了解任何知识 完整项目github链接:https://github.com/git-Code-Shelf/M ...
- JavaScript 是如何工作:Shadow DOM 的内部结构 + 如何编写独立的组件!
这是专门探索 JavaScript 及其所构建的组件的系列文章的第 17 篇. 如果你错过了前面的章节,可以在这里找到它们: JavaScript 是如何工作的:引擎,运行时和调用堆栈的概述! Jav ...
随机推荐
- NSSCTF Round#11 Basic 密码个人赛复盘
[NSSRound#11 Basic]ez_enc ABAABBBAABABAABBABABAABBABAAAABBABABABAAABAAABBAABBBBABBABBABBABABABAABBAA ...
- phpcms - 在删除文章后实现自动删除tag标签
在使用phpcms程序制作网站的时候,我们会发现文章模型新建一篇文章后会自动向数据库中插入关键词,但如果删除文章后,数据库中的关键词表中字段中还存在之前文章的关键词,那么怎样才能在phpcms后台中删 ...
- Laravel - 解决 $.ajax success 返回的数据为空的问题 (后台为laravel)
原因之一 : 后台 dump()打印 , 去掉或者注释就好了
- [转帖]linux系统主机双网卡实现路由转发问题与解决
1. 环境 拓扑: 网卡配置: host1: 192.168.1.1/24 host2: 左eth0: 192.168.1.2/24 右eth1: 192.168.2.2/24 host3: 192. ...
- [转帖]TiKV Config Learn the TiKV configuration file
The TiKV configuration file supports more options than command-line parameters. You can find the def ...
- [转帖]TiKV Control 使用说明
https://docs.pingcap.com/zh/tidb/stable/tikv-control TiKV Control(以下简称 tikv-ctl)是 TiKV 的命令行工具,用于管理 T ...
- [转帖]decimal,float和double的区别是什么?
https://zhuanlan.zhihu.com/p/352503879 今天复习mysql理论知识,在看常用数据类型的时候发现float和decimal类型都是表示小数,就展开搜索学习了一下区别 ...
- [转帖]如何利用wrarp测试oss性能?
https://zhuanlan.zhihu.com/p/529735003 前言 我们利用mino与ceph rgw搭建好的oss经过多层网络转发,传输速度必定有所折损,这个时候我们使用wrap ...
- [转帖]Debian9换源(阿里源)(Linux子系统)
http://www.taodudu.cc/news/show-5410026.html?action=onClick 默认你已经装好Linux子系统. Step 0: 换源核心就是把/etc/apt ...
- [转帖]Linux文件夹对比并提取的差分文件技巧-rsync的妙用
https://www.xitongjiaocheng.com/linux/2017/45720.html 需求 最近团队正在开发一个版本对比工具,要求是把A1文件夹与A2对比,将A2中的增量部分 ...