HTMLSlotElement
The HTMLSlotElement
interface of the Shadow DOM API enables access to the name and assigned nodes of an HTML <slot>
element.
Properties
HTMLSlotElement.name
-
DOMString
: Can be used to get and set the slot's name.
Methods
HTMLSlotElement.assignedNodes()
- Returns the sequence of elements assigned to this slot, or alternatively the slot's fallback content.
Examples
The following snippet is taken from our slotchange example (see it live also).
let slots = this.shadowRoot.querySelectorAll('slot');
slots[1].addEventListener('slotchange', function(e) {
let nodes = slots[1].assignedNodes();
console.log('Element in Slot "' + slots[1].name + '" changed to "' + nodes[0].outerHTML + '".');
});
Here we grab references to all the slots, then add a slotchange event listener to the 2nd slot in the template — which is the one that keeps having its contents changed in the example.
Every time the element inserted in the slot changes, we log a report to the console saying which slot has changed, and what the new node inside the slot is.
Specifications
|
Desktop |
|
Chrome |
Edge |
Firefox |
Internet Explorer |
Opera |
Safari |
Basic support
|
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
No |
40 |
10.1 |
name
|
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
No |
40 |
10.1 |
assignedNodes
|
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
No |
40 |
10.1 |
|
Mobile |
|
Android webview |
Chrome for Android |
Edge Mobile |
Firefox for Android |
Opera for Android |
iOS Safari |
Samsung Internet |
Basic support
|
53 |
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
40 |
10.1 |
6.0 |
name
|
53 |
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
40 |
10.1 |
6.0 |
assignedNodes
|
53 |
53 |
No
- No
- Under consideration
|
63
- 63
- 59
Disabled
- Disabled From version 59: this feature is behind the
dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
- ? — 59
Disabled
- Disabled Until version 59 (exclusive): this feature is behind the
dom.webcomponents.enabled preference (needs to be set to true ) and the dom.webcomponents.shadowdom.enabled preference (needs to be set to true ). To change preferences in Firefox, visit about:config.
|
40 |
10.1 |
6.0 |