blob: 0a1c7971e554d1c31050062a5e59a8e6b63d42ca (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
---
title: <slot>
slug: Web/HTML/Element/slot
tags:
- Composant web
- Element
- HTML
- Reference
- Web
- shadow dom
translation_of: Web/HTML/Element/slot
---
{{HTMLRef}}
L'élément HTML **`<slot>`** représente un emplacement d'un composant web qu'on peut remplir avec son propre balisage. On peut ainsi obtenir un document construit avec différents arbres DOM. Cet élément fait partie des outils relatifs [aux composants web (Web Components)](/fr/docs/Web/Web_Components).
## Attributs
Cet élément inclut [les attributs universels](/fr/docs/Web/HTML/Attributs_universels).
- {{htmlattrdef("name")}}
- : Le nom de l'emplacement créé.
Un **_« slot » nommé_** est un élément `<slot>` avec un attribut `name`.
## Exemples
```html
<template id="element-details-template">
<style>
details {font-family: "Open Sans Light", Helvetica, Arial, sans-serif }
.name {font-weight: bold; color: #217ac0; font-size: 120% }
h4 {
margin: 10px 0 -8px 0;
background: #217ac0;
color: white;
padding: 2px 6px;
border: 1px solid #cee9f9;
border-radius: 4px;
}
.attributes { margin-left: 22px; font-size: 90% }
.attributes p { margin-left: 16px; font-style: italic }
</style>
<details>
<summary>
<code class="name"><<slot name="element-name">Remplacer ce nom</slot>></code>
<i class="desc"><slot name="description">Remplacer cette description</slot></i>
</summary>
<div class="attributes">
<h4>Attributs</h4>
<slot name="attributes"><p>Aucun</p></slot>
</div>
</details>
<hr>
</template>
```
> **Note :** Vous pouvez retrouver cet exemple sur [ce dépôt GitHub](https://github.com/mdn/web-components-examples/tree/master/element-details) et observer [son fonctionnement en live ici](https://mdn.github.io/web-components-examples/element-details/). Une explication plus détaillée est également disponible avec l'article [Manipuler `template` et `slot`](/fr/docs/Web/Web_Components/Using_templates_and_slots).
## Résumé technique
<table class="properties">
<tbody>
<tr>
<th scope="row">
<a href="/fr/docs/Web/HTML/Catégorie_de_contenu"
>Catégories de contenu</a
>
</th>
<td>
<a href="/fr/docs/Web/HTML/Catégorie_de_contenu#Contenu_de_flux"
>Contenu de flux</a
>,
<a href="/fr/docs/Web/HTML/Catégorie_de_contenu#Contenu_phrasé"
>contenu phrasé</a
>.
</td>
</tr>
<tr>
<th scope="row">Contenu autorisé</th>
<td>
<a
href="/fr/docs/Web/HTML/Catégorie_de_contenu#Modèle_de_contenu_transparent"
>Contenu transparent</a
>.
</td>
</tr>
<tr>
<th scope="row">Évènements</th>
<td>{{event("slotchange")}}</td>
</tr>
<tr>
<th scope="row">Omission de balises</th>
<td>{{no_tag_omission}}</td>
</tr>
<tr>
<th scope="row">Parents autorisés</th>
<td>
Tout élément qui accepte du
<a href="/fr/docs/Web/HTML/Catégorie_de_contenu#Contenu_phrasé"
>contenu phrasé</a
>.
</td>
</tr>
<tr>
<th scope="row">Rôles ARIA autorisés</th>
<td>Aucun.</td>
</tr>
<tr>
<th scope="row">Interface DOM</th>
<td>{{domxref("HTMLSlotElement")}}</td>
</tr>
</tbody>
</table>
## Spécifications
| Spécification | État | Commentaires |
| ---------------------------------------------------------------------------------------------------- | -------------------------------- | ------------ |
| {{SpecName('HTML WHATWG','scripting.html#the-slot-element','<slot>')}} | {{Spec2('HTML WHATWG')}} | |
| {{SpecName('DOM WHATWG','#shadow-tree-slots','Slots')}} | {{Spec2('DOM WHATWG')}} | |
## Compatibilité des navigateurs
{{Compat("html.elements.slot")}}
## Voir aussi
- {{HTMLElement("template")}}
|