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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
|
---
title: Éléments en ligne
slug: Web/HTML/Inline_elements
tags:
- Beginner
- Débutant
- Elements
- Guide
- HTML
- HTML Elements
- Layout
- Reference
translation_of: Web/HTML/Inline_elements
original_slug: Web/HTML/Éléments_en_ligne
---
Les éléments HTML (**Hypertext Markup Language**) étaient historiquement catégorisés comme des éléments de type « bloc » (_block_ en anglais) ou de type « en ligne » (_inline_ en anglais). Comme il s'agit d'une caractéristique de présentation, elle est aujourd'hui spécifiée par CSS dans le module de spécification [_Flow Layout_](/fr/docs/Web/CSS/CSS_Flow_Layout) qui définit l'organisation visuelle par défaut des éléments (le « flux » normal). Les éléments en lignes n'occupent que l'espace entre leurs balises et s'insèrent dans le flux du contenu plutôt que de créer un nouveau « bloc » visuel. Dans cet article, nous verrons en détails ces éléments en ligne et leurs différences par rapport aux [éléments de bloc](/fr/docs/Web/HTML/Block-level_elements).
> **Note :** Un élément en ligne ne commence pas sur une nouvelle ligne et prend uniquement la largeur qui lui est nécessaire.
## Éléments en ligne et éléments de bloc : un exemple
Un exemple vaut mieux qu'une longue explication. Voici pour commencer la feuille de style CSS que nous utiliserons :
```css
.highlight {
background-color:#ee3;
}
```
### Élément en ligne
Le fragment de code HTML qui suit utilise un élément en ligne avec la classe `highlight` :
```html
<p>L'élément span qui suit est un <span class="highlight">élément en ligne</span> ;
son arrière-plan est coloré afin d'illustrer la zone couverte par cet élément en
ligne.</p>
```
Dans cet exemple, l'élément [`<p>`](/fr/docs/Web/HTML/Element/p) (le paragraphe) est un élément de bloc qui contient du texte. Dans ce texte, on a un élément [`<span>`](/fr/docs/Web/HTML/Element/span) qui est un élément en ligne. L'élément `<span>` étant un élément en ligne, le paragraphe est bien affiché sous la forme d'un flux de texte sans rupture :
{{EmbedLiveSample("Inline", "", 120)}}
```css hidden
body {
margin: 0;
padding: 4px;
border: 1px solid #333;
}
.highlight {
background-color:#ee3;
}
```
### Élément de bloc
Transformons l'exemple précédent pour passer d'un élément `<span>` à un élément [`<div>`](/fr/docs/Web/HTML/Element/div) qui est un élément de bloc :
```html
<p>L'élément div qui suit est un <div class="highlight">élément de bloc</div> ;
son arrière-plan est coloré afin d'illustrer la zone couverte par cet élément de
bloc.</p>
```
```css hidden
body {
margin: 0;
padding: 4px;
border: 1px solid #333;
}
.highlight {
background-color:#ee3;
}
```
Et voici le résultat qu'on obtient :
{{EmbedLiveSample("Block-level", "", 150)}}
On voit ici que l'élément `<div>` modifie complètement la disposition du texte et le découpe en trois parties : une partie avant le `<div>`, une partie constituée avec le texte de l'élément `<div>` et une dernière partie ensuite.
### Modifier le type d'un d'élément
Il est possible de choisir le mode d'affichage d'un élément afin de modifier son comportement par défaut grâce à la propriété CSS [`display`](/fr/docs/Web/CSS/display). En passant la valeur de `display` de `"inline"` à `"block"`, on peut indiquer au navigateur d'afficher l'élément comme une boîte de bloc plutôt que comme une boîte en ligne. Attention, l'élément ne sera plus affiché de la même façon, vérifiez le résultat obtenu. De plus, ce changement n'impactera pas la catégorie et le modèle de contenu de l'élément : utiliser `display:block` sur un élément [`<span>`](/fr/docs/Web/HTML/Element/span) ne permettra toujours pas de lui imbriquer un élément [`<div>`](/fr/docs/Web/HTML/Element/div) à l'intérieur.
## Différences conceptuelles
Voici, en résumé, les différences conceptuelles entre les éléments en ligne et les éléments de bloc :
- Modèle de contenu
- : En général, les éléments en ligne ne peuvent contenir que des données ou d'autres éléments en ligne. Il n'est pas possible de placer des éléments de bloc à l'intérieur d'éléments en ligne.
- Formatage
- : Par défaut, les éléments en ligne n'introduisent pas de saut de ligne dans le flux du document. En revanche, les éléments de bloc provoquent un saut de ligne (ce comportement peut être modifié grâce au CSS).
## Liste des éléments en ligne
Bien que cette notion de présentation soit désormais (depuis HTML5) portée par le CSS et remplacée par les [catégories de contenu](/fr/docs/Web/Guide/HTML/Content_categories), voici les éléments HTML qui se comportent par défaut comme des éléments en ligne:
- [`<a>`](/fr/docs/Web/HTML/Element/a)
- [`<abbr>`](/fr/docs/Web/HTML/Element/abbr)
- [`<acronym>`](/fr/docs/Web/HTML/Element/acronym)
- [`<audio>`](/fr/docs/Web/HTML/Element/audio) (si les contrôles sont visibles)
- [`<b>`](/fr/docs/Web/HTML/Element/b)
- [`<bdi>`](/fr/docs/Web/HTML/Element/bdi)
- [`<bdo>`](/fr/docs/Web/HTML/Element/bdo)
- [`<big>`](/fr/docs/Web/HTML/Element/big)
- [`<br>`](/fr/docs/Web/HTML/Element/br)
- [`<button>`](/fr/docs/Web/HTML/Element/Button)
- [`<canvas>`](/fr/docs/Web/HTML/Element/canvas)
- [`<cite>`](/fr/docs/Web/HTML/Element/cite)
- [`<code>`](/fr/docs/Web/HTML/Element/code)
- [`<data>`](/fr/docs/Web/HTML/Element/data)
- [`<datalist>`](/fr/docs/Web/HTML/Element/datalist)
- [`<del>`](/fr/docs/Web/HTML/Element/del)
- [`<dfn>`](/fr/docs/Web/HTML/Element/dfn)
- [`<em>`](/fr/docs/Web/HTML/Element/em)
- [`<embed>`](/fr/docs/Web/HTML/Element/embed)
- [`<i>`](/fr/docs/Web/HTML/Element/i)
- [`<iframe>`](/fr/docs/Web/HTML/Element/iframe)
- [`<img>`](/fr/docs/Web/HTML/Element/Img)
- [`<input>`](/fr/docs/Web/HTML/Element/Input)
- [`<ins>`](/fr/docs/Web/HTML/Element/ins)
- [`<kbd>`](/fr/docs/Web/HTML/Element/kbd)
- [`<label>`](/fr/docs/Web/HTML/Element/Label)
- [`<map>`](/fr/docs/Web/HTML/Element/map)
- [`<mark>`](/fr/docs/Web/HTML/Element/mark)
- [`<meter>`](/fr/docs/Web/HTML/Element/Meter)
- [`<noscript>`](/fr/docs/Web/HTML/Element/noscript)
- [`<object>`](/fr/docs/Web/HTML/Element/object)
- [`<output>`](/fr/docs/Web/HTML/Element/output)
- [`<picture>`](/fr/docs/Web/HTML/Element/picture)
- [`<progress>`](/fr/docs/Web/HTML/Element/Progress)
- [`<q>`](/fr/docs/Web/HTML/Element/q)
- [`<ruby>`](/fr/docs/Web/HTML/Element/ruby)
- [`<s>`](/fr/docs/Web/HTML/Element/s)
- [`<samp>`](/fr/docs/Web/HTML/Element/samp)
- [`<script>`](/fr/docs/Web/HTML/Element/script)
- [`<select>`](/fr/docs/Web/HTML/Element/select)
- [`<slot>`](/fr/docs/Web/HTML/Element/slot)
- [`<small>`](/fr/docs/Web/HTML/Element/small)
- [`<span>`](/fr/docs/Web/HTML/Element/span)
- [`<strong>`](/fr/docs/Web/HTML/Element/strong)
- [`<sub>`](/fr/docs/Web/HTML/Element/sub)
- [`<sup>`](/fr/docs/Web/HTML/Element/sup)
- [`<svg>`](/fr/docs/Web/SVG/Element/svg)
- [`<template>`](/fr/docs/Web/HTML/Element/template)
- [`<u>`](/fr/docs/Web/HTML/Element/u)
- [`<tt>`](/fr/docs/Web/HTML/Element/tt)
- [`<var>`](/fr/docs/Web/HTML/Element/var)
- [`<video>`](/fr/docs/Web/HTML/Element/video)
- [`<wbr>`](/fr/docs/Web/HTML/Element/wbr)
## Voir aussi
- [Les éléments de bloc](/fr/docs/Web/HTML/Block-level_elements)
- [Référence des éléments HTML](/fr/docs/Web/HTML/Element)
- [La propriété CSS `display`](/fr/docs/Web/CSS/display)
- [Les catégories de contenu](/fr/docs/Web/Guide/HTML/Content_categories)
- [Les éléments de bloc et les éléments en ligne dans le flux normal](/fr/docs/Web/CSS/CSS_Flow_Layout/Block_and_Inline_Layout_in_Normal_Flow)
{{QuickLinksWithSubpages("/fr/docs/Web/HTML/")}}
|