mirror of
https://github.com/m-lamonaca/dev-notes.git
synced 2025-04-06 10:56:41 +00:00
add Shadow DOM notes
This commit is contained in:
parent
f9d5e84311
commit
a42763b290
2 changed files with 71 additions and 0 deletions
1
docs/img/webcomponents_shadowdom.svg
Normal file
1
docs/img/webcomponents_shadowdom.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 15 KiB |
|
@ -98,6 +98,76 @@ class CustomElement extends HTMLElement {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## [Shadow DOM][using-shadow-dom-mdn]
|
||||||
|
|
||||||
|
THe **Shadow DOM** allows to attach a DOM tree to an element, and have the internals of this tree hidden from JavaScript and CSS running in the page.
|
||||||
|
|
||||||
|
The shadow DOM tree starts with a shadow root, underneath which it's possible to attach any element, in the same way as the normal DOM.
|
||||||
|
|
||||||
|
Terminology:
|
||||||
|
|
||||||
|
- **Shadow host**: The regular DOM node that the shadow DOM is attached to.
|
||||||
|
- **Shadow tree**: The DOM tree inside the shadow DOM.
|
||||||
|
- **Shadow boundary**: the place where the shadow DOM ends, and the regular DOM begins.
|
||||||
|
- **Shadow root**: The root node of the shadow tree.
|
||||||
|
|
||||||
|
![shadow-dom-schema]
|
||||||
|
|
||||||
|
### Creating a Shadow DOM
|
||||||
|
|
||||||
|
```html
|
||||||
|
<div id="host"></div>
|
||||||
|
<span>I'm not in the shadow DOM</span>
|
||||||
|
```
|
||||||
|
|
||||||
|
```js
|
||||||
|
const host = document.querySelector("#host");
|
||||||
|
const shadow = host.attachShadow({ mode: "open" });
|
||||||
|
const span = document.createElement("span");
|
||||||
|
span.textContent = "I'm in the shadow DOM";
|
||||||
|
shadow.appendChild(span);
|
||||||
|
```
|
||||||
|
|
||||||
|
> **Note**: `{mode: "open"}` allows accessing the shadow DOM from the _root node_ `shadowDom` property. The "close" mode does not expose this property.
|
||||||
|
|
||||||
|
### JavaScript & CSS Encapsulation
|
||||||
|
|
||||||
|
The JavaScript and CSS defined outside the shadow DOM do not have effect inside. To style a shadow dom there are two possibilities:
|
||||||
|
|
||||||
|
- defining a `CSSStylesheet` and assigning it to the `ShadowRoot: adoptedStyleSheets`
|
||||||
|
- adding a `<style>` element in a `<template>` element's declaration.
|
||||||
|
|
||||||
|
```js
|
||||||
|
const sheet = new CSSStyleSheet();
|
||||||
|
sheet.replaceSync("span { color: red; border: 2px dotted black; }");
|
||||||
|
|
||||||
|
const host = document.querySelector("#host");
|
||||||
|
|
||||||
|
const shadow = host.attachShadow({ mode: "open" });
|
||||||
|
shadow.adoptedStyleSheets = [sheet];
|
||||||
|
|
||||||
|
const span = document.createElement("span");
|
||||||
|
span.textContent = "I'm in the shadow DOM";
|
||||||
|
shadow.appendChild(span);
|
||||||
|
```
|
||||||
|
|
||||||
|
```html
|
||||||
|
<template id="custom-element">
|
||||||
|
<style>
|
||||||
|
span {
|
||||||
|
color: red;
|
||||||
|
border: 2px dotted black;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<span>I'm in the shadow DOM</span>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<div id="host"></div>
|
||||||
|
<span>I'm not in the shadow DOM</span>
|
||||||
|
```
|
||||||
|
|
||||||
<!-- links -->
|
<!-- links -->
|
||||||
[web-components-mdn]: https://developer.mozilla.org/en-US/docs/Web/API/Web_Components "Web Components Docs"
|
[web-components-mdn]: https://developer.mozilla.org/en-US/docs/Web/API/Web_Components "Web Components Docs"
|
||||||
[using-cusotom-elements-mdn]: https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_custom_elements "Using Custom Elements"
|
[using-cusotom-elements-mdn]: https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_custom_elements "Using Custom Elements"
|
||||||
|
[using-shadow-dom-mdn]: https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_shadow_DOM "Using Shadow DOM"
|
||||||
|
[shadow-dom-schema]: ../img/webcomponents_shadowdom.svg
|
||||||
|
|
Loading…
Add table
Reference in a new issue