You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardExpand all lines: 8-web-components/3-shadow-dom/article.md
+24-23Lines changed: 24 additions & 23 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -1,28 +1,28 @@
1
-
# Shadow DOM
1
+
# Тіньовий DOM (Shadow DOM)
2
2
3
-
Тіньовий DOM ('Shadow DOM') використовується для інкапсуляції. Він дозволяє компоненту мати своє власне "тіньове" DOM-дерево, що не може бути випадково доступним з головного документу, a також може мати власні локальні правила стилів, та ін.
3
+
Тіньовий DOM ('Shadow DOM') використовується для інкапсуляції. Він дозволяє компоненті мати своє власне "тіньове" DOM-дерево, що не може бути випадково змінено з головного документу, a також може мати власні локальні стилі, та ін.
4
4
5
-
## Вбудований shadow DOM
5
+
## Вбудований тіньовий DOM
6
6
7
-
Чи замислювались ви коли-небудь, як влаштовані та стилізовані складні браузерні елементи керування?
7
+
Чи замислювались ви коли-небудь, як влаштовані та стилізовані складні браузерні інтерактивні елементи?
8
8
9
9
Такі як `<input type="range">`:
10
10
11
11
<p>
12
12
<inputtype="range">
13
13
</p>
14
14
15
-
Браузер використовує DOM/CSS на свій розсуд, щоб відобразити їх. Така структура DOM зазвичай прихована від нас, але ми можемо її побачити в інструментах розробника. Наприклад, у Chrome нам знадобиться активувати опцію "Show user agent shadow DOM".
15
+
Браузер використовує DOM/CSS на свій розсуд, щоб відобразити їх. Така структура DOM зазвичай прихована від нас, але ми можемо її побачити в інструментах розробника. Наприклад, у Chrome нам знадобиться активувати опцію "Show user agent shadow DOM".
16
16
17
17
Отже, `<input type="range">` виглядає так:
18
18
19
19

20
20
21
21
Те, що відображено під `#shadow-root` і є "тіньовим DOM" (shadow DOM).
22
22
23
-
Ми не можемо отримати доступ до тіньового DOM вбудованих елементів засобами звичайних JavaScript-викликів чи за допомогою селекторів. Це не просто звичайні нащадки, а потужний засіб інкапсуляції.
23
+
Ми не можемо отримати доступ до тіньового DOM вбудованих елементів звичайними засобами JavaScript чи за допомогою селекторів. Це не просто дочірні елементи, а потужний спосіб інкапсуляції, тобто захисту від зовнішнього втручання у внутрішню структуру.
24
24
25
-
У вищенаведеному прикладі зверніть увагу на корисний атрибут `pseudo`. Він є нестандартним та існує через історичні причини. Його можна використовувати задля стилізації піделементи через CSS, наприклад, так:
25
+
У вищенаведеному прикладі зверніть увагу на корисний атрибут `pseudo`. Він є нестандартним та існує через історичні причини. Його можна використовувати задля стилізації вкладених елементів через CSS, наприклад, так:
Наголошуємо, `pseudo` є нестандартним атрибутом. Хронологічно, браузери спочатку почали експерементувати з внутрішнімі DOM-структурами для здійснення контролю, а потім, через певний час, тіньовий DOM було стандартизовано, щоб дати можливість нам, розробникам, робити те саме.
38
+
Наголошуємо, `pseudo` є нестандартним атрибутом. Історично, браузери спочатку почали експерементувати зі внутрішнімі DOM-структурами для створення інтерактивних елементів, і тільки потім, через певний час, тіньовий DOM було стандартизовано, щоб надати можливість нам, розробникам, робити те саме.
39
39
40
-
Надалі ми використовуватимемо сучасний тіньовий стандарт DOM, покритий [DOM специфікацією](https://dom.spec.whatwg.org/#shadow-trees) та іншими спорідненими специфікаціями.
40
+
Надалі ми використовуватимемо сучасний тіньовий стандарт DOM, відображений у [DOM специфікації](https://dom.spec.whatwg.org/#shadow-trees) та в інших споріднених специфікаціях.
41
41
42
42
## Тіньове дерево
43
43
@@ -46,9 +46,9 @@ DOM-елемент може мати два типи DOM піддерев:
46
46
1. Light tree -- звичайне "cвітле" DOM піддерево, що складається з HTML-нащадків. Усі піддерева, про які йшлося у попередніх розділах, були "cвітлі".
47
47
2. Shadow tree -- приховане "тіньове" DOM піддерево, не відображене у HTML та сховане від сторонніх очей.
48
48
49
-
Якщо елемент має обидва, то браузер відмальовує тільки тіньове дерево. Також ми можемо встановити певний вид композиції між тіньовим та світлим деревами. Ми обговоримо ці деталі надалі у розділі <info:slots-composition>.
49
+
Якщо елемент має обидва, то браузер відображає тільки тіньове дерево. Також ми можемо встановити певний вид композиції (взаємодії) між тіньовим та світлим деревами. Ми обговоримо ці деталі надалі у розділі <info:slots-composition>.
50
50
51
-
Тіньове дерево може бути використаним в користувацьких елементах (сustom elements), щоб приховати внутрішній склад компонента і застосувати до нього локальні стилі.
51
+
Тіньове дерево може бути використаним в користувацьких елементах (сustom elements), щоб приховати внутрішню структуру компонента і застосувати до нього локальні стилі, захищені від зовнішнього втручання.
52
52
53
53
Наприклад, цей `<show-hello>` елемент приховує свій внутрішній DOM у тіньовому дереві:
54
54
@@ -75,19 +75,19 @@ customElements.define('show-hello', class extends HTMLElement {
75
75
76
76
Існує два обмеження:
77
77
1. Для одного елементу можливо створити тільки один тіньовий root.
78
-
2.`elem` повинен бути або кастомним елементом, або одним з наступних: "article", "aside", "blockquote", "body", "div", "footer", "h1..h6", "header", "main" "nav", "p", "section", or "span". Інші елементи, як `<img>`, не можуть містити тіньове дерево.
78
+
2.`elem` повинен бути або кастомним елементом, або одним з наступних: "article", "aside", "blockquote", "body", "div", "footer", "h1..h6", "header", "main" "nav", "p", "section", or "span". Інші елементи, такі як `<img>`, не можуть містити тіньове дерево.
79
79
80
80
Опція `mode` встановлює рівень інкапсуляції, вона повинна мати одне з двох значень:
81
81
-`"open"` -- тіньовий root доступний як `elem.shadowRoot`.
82
82
83
83
Будь-який код має доступ до тіньового дерева `elem`.
84
84
-`"closed"` -- `elem.shadowRoot` завжди `null`.
85
85
86
-
Ми можемо отримати доступ до тіньового DOM тільки по посиланню, яке повертається `attachShadow` (і, можливо, приховане у класі). Вбудовані браузерні нативні дерева, такі, як `<input type="range">`, є закритими, до них не дібратись.
86
+
Ми можемо отримати доступ до тіньового DOM тільки по посиланню, яке повертається `attachShadow` (і, можливо, приховане у класі). Вбудовані браузерні нативні дерева, такі, як `<input type="range">`, є закритими, до них не дістатись.
87
87
88
88
[Тіньовий root](https://dom.spec.whatwg.org/#shadowroot), який повертає `attachShadow`, поводиться як елемент: ми можемо використовувати `innerHTML` чи DOM-методи, такі як `append`, щоб заповнити його.
89
89
90
-
Елемент з тіньового root називається "хазяїн" (shadow tree host) і доступний як властивість `host` у shadow root.
90
+
Елемент з тіньового root називається "shadow tree host" і доступний як властивість `host` у shadow root.
91
91
92
92
```js
93
93
// за умови {mode: "open"}, інакше elem.shadowRoot це null
Тіньовий DOM цілковито відокремлений від основного документу:
100
100
101
-
1. Елементи тіньового DOM невидимі для `querySelector` зі світлого DOM. Зокрема, тіньовий DOM елемент може мати ідентифікатори, що конфліктують з одноіменними зі світлого DOM. Вони повинні бути унікальними тільки всередині тіньового дерева.
101
+
1. Елементи тіньового DOM невидимі для `querySelector` зі світлого DOM. Зокрема, тіньовий DOM елемент може мати всередині атрибути `id` зі значеннями, що конфліктують з однойменними зі світлого DOM. Вони повинні бути унікальними тільки всередині тіньового дерева.
102
102
2. Тіньовий DOM має власні стилі. Стильові правила з зовнішнього DOM не застосовуються.
103
103
104
104
Наприклад:
105
105
106
106
```html run untrusted height=40
107
107
<style>
108
108
*!*
109
-
/* стилі документа не застосовуються до тіньового дерева в середині #elem (1) */
109
+
/* стилі документа не застосовуються до тіньового дерева всередині #elem (1) */
- Тіньовий DOM згадується у багатьох інших специфікаціях, наприклад, [DOM Parsing](https://w3c.github.io/DOM-Parsing/#the-innerhtml-mixin) вказує на те, що у shadow root є `innerHTML`.
143
143
144
-
## Висновки
145
144
146
-
Тіньовий DOM – це спосіб створити ізольоване DOM-дерево для компонента.
145
+
## Підсумки
146
+
147
+
Тіньовий DOM -- це спосіб створити ізольоване DOM-дерево для компоненти.
147
148
148
149
1.`shadowRoot = elem.attachShadow({mode: open|closed})` -- створює тіньовий DOM для `elem`. Якщо `mode="open"`, то він є досяжним як властивість `elem.shadowRoot`.
149
-
2. Ми можемо створити піделементи `shadowRoot`, використовуючи `innerHTML` чи інші методи DOM.
150
+
2. Ми можемо записати щось всередину`shadowRoot`, використовуючи `innerHTML` чи інші DOM-методи.
150
151
151
152
Тіньові елементи DOM:
152
-
- Мають власну область видимості ідентифікаторів;
153
-
- Невидимі для селекторів JavaScript з головного документу, таким, як `querySelector`;
154
-
- Використовують стилі тільки з тіньового дерева, не з головного документу.
153
+
- Мають окрему область для унікальності значень в атрибутах `id` HTML-елементів,
154
+
- Невидимі для селекторів JavaScript з головного документу, таким методам, як `querySelector`;
155
+
- Використовують стилі тільки з тіньового дерева, а не глобальні стилі документу.
155
156
156
157
Тіньовий DOM, якщо існує, рендериться браузером замість так званого "світлого DOM" (звичайних нащадків). У главі <info:slots-composition> ми розберемо, як поєднювати їх.
0 commit comments