aboutsummaryrefslogtreecommitdiff
path: root/files/fr/apprendre/css/introduction_à_css/la_disposition/index.html
blob: 526af5a0b0ab64cf6ec5c7c9d7c43798af9a2ec5 (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
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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
---
title: La disposition en CSS
slug: Apprendre/CSS/Introduction_à_CSS/La_disposition
tags:
  - Apprendre
  - CSS
translation_of: Learn/CSS/CSS_layout/Introduction
translation_of_original: Learn/CSS/Basics/Layout
---
<p>{{PreviousNext("Apprendre/CSS/Les_bases/Le_modèle_de_boîte","Apprendre/CSS/Comment/Mettre_en_forme_du_texte")}}</p>

<p class="summary"><span class="seoSummary">Pour organiser un document en positionnant ses éléments pour que la forme corresponde aux spécifications, on utilisera différentes propriétés CSS afin d'organiser la disposition des élément.</span> CSS fournit de nombreux mécanismes pour organiser la disposition du contenu d'un document et les techniques modernes sont suffisamment complexes pour être décrites dans des articles séparés. Dans cet article, nous verrons les techniques de base, utilisées depuis plusieurs années.</p>

<p>Pour organiser correctement la disposition d'un document avec CSS, il y a quelques notions qu'il est préférable de connaître. Le concept le plus important est le flux du texte {{Glossary("HTML")}} et les façons dont on peut le modifier. Ces concepts clés sont essentiels et tous les mécanismes liés à la disposition feront référence à ce qui est expliqué ici..</p>

<h2 id="Le_flux">Le flux</h2>

<p>Simplifié à l'extrême, un document HTML est un document texte organisé avec des {{Glossary("balise","balises")}}. Dans un tel document, le texte « coule » sur les différentes lignes. Autrement dit, le texte est affiché dans le sens de lecture (de gauche à droite pour les langages latins comme le français ou l'italien) et est fragmenté automatiquement pour passer à la ligne à chaque fois que le texte atteint le bord du document.</p>

<p><img alt="" src="https://mdn.mozillademos.org/files/11955/line-break-flow.svg" style="height: auto; max-width: 450px;"></p>

<p><img alt="" src="https://mdn.mozillademos.org/files/11955/line-break-flow.svg#large" style="height: auto; max-width: 450px;"></p>

<p>Chaque {{Glossary("élément")}} du document pourra modifier ce flux de texte :</p>

<ul>
 <li>Certains éléments suivront simplement le flux, comme s'ils n'existaient pas</li>
 <li>Certains éléments pourront forcer le passage à la ligne, que le texte ait atteint la limite du document ou non</li>
 <li>Certains éléments pourront créer un nouveau flux de texte pour leur contenu, flux indépendant du flux de texte « extérieur ».</li>
</ul>

<h3 id="Les_catégories_d'affichage_des_éléments">Les catégories d'affichage des éléments</h3>

<p>CSS est utilisé pour définir la façon dont un élément HTML se comporte dans ce flux et comment il s'y inscrit. Le comportement d'un élément est défini avec la propriété {{cssxref('display')}}. Cette propriété peut prendre plusieurs valeurs mais voyons ici les quatre valeurs les plus importantes :</p>

<dl>
 <dt><code>none</code></dt>
 <dd>Cette valeur retire l'élément du flux, comme si l'élément et son contenu n'existaient pas.</dd>
 <dt><code>inline</code></dt>
 <dd>Cette valeur rend l'élément transparent au sens où il s'inscrit dans le flux de texte global, il est donc associé au texte l'environnant.</dd>
 <dt><code>block</code></dt>
 <dd>Cette valeur cassera le flux de texte pour insérer l'élément. Cela provoquera donc un saut de ligne avant et après. Le contenu de cet élément ne fait donc pas partie du flux global et suit donc les contraintes de l'élément définies par <a href="/fr/Apprendre/CSS/Les_bases/Le_modèle_de_boîte">le modèle de boîte</a>.</dd>
 <dt><code>inline-block</code></dt>
 <dd>Cette valeur est en quelque sorte un intermédiaire entre <code>inline</code> et <code>block</code>. Comme avec <code>inline</code>, les boîtes seront placées dans le flux global mais , comme avec <code>block</code>, le contenu ne fera pas partie du texte environnant..</dd>
</dl>

<p>Prenons un exemple.</p>

<p>Voici le code HTML qui sera utilisé :</p>

<pre class="brush: html">&lt;p class="none"&gt;
  1. Je suis un chat noir,
  &lt;span&gt;qui marche sous l'échelle &lt;/span&gt;
  et qui casse des miroirs.
&lt;/p&gt;

&lt;p class="inline"&gt;
  2. Je suis un chat noir,
  &lt;span&gt;qui marche sous l'échelle &lt;/span&gt;
  et qui casse des miroirs.
&lt;/p&gt;

&lt;p class="block"&gt;
  3. Je suis un chat noir,
  &lt;span&gt;wqui marche sous l'échelle &lt;/span&gt;
  et qui casse des miroirs.
&lt;/p&gt;

&lt;p class="inline-block"&gt;
  4. Je suis un chat noir,
  &lt;span&gt;qui marche sous l'échelle &lt;/span&gt;
  et qui casse des miroirs.
&lt;/p&gt;
</pre>

<p>On appliquera la feuille de style CSS suivante :</p>

<pre class="brush: css">span {
  width: 5em;
  background: yellow;
}

.none span         { display: none;         }
.inline span       { display: inline;       }
.block span        { display: block;        }
.inline-block span { display: inline-block; }</pre>

<p>Cela fournira le résultat suivant :</p>

<p>{{EmbedLiveSample("Les_catégories_d'affichage_des_éléments", '100%', '300px')}}</p>

<h2 id="Modifier_le_flux">Modifier le flux</h2>

<p>En utilisant la propriété <code>display</code>, vous pouvez déjà modifier le flux. Il est toutefois possible d'aller plus loin.</p>

<h3 id="La_disposition_du_texte">La disposition du texte</h3>

<p>En fin de compte, un document n'est qu'un long flux de texte et CSS fournit de nombreuses propriétés pour gérer la disposition du texte. La disposition du texte regroupe tout ce qui touche aux règles des sauts de ligne et à la façon dont le texte est positionné par rapport à la ligne de base naturelle.</p>

<p>Ces propriétés sont : {{cssxref("hyphens")}}, {{cssxref("text-align")}}, {{cssxref("text-align-last")}}, {{cssxref("text-indent")}}, {{cssxref("vertical-align")}}, {{cssxref("white-space")}}, {{cssxref("word-break")}} et {{cssxref("word-wrap")}}.</p>

<p>À l'exception de <code>text-align</code> et de <code>text-indent</code>, les autres propriétés ont des effets plutôt subtils sur le texte. Quant à <code>vertical-align</code>, il est souvent utilisé avec des boîtes en mode <code>inline-block</code>.</p>

<p>Là encore, un exemple vaut mieux qu'un long discours.</p>

<p>HTML :</p>

<pre class="brush: html">&lt;p lang="en"&gt;WHEN Scrooge awoke, it was so dark, that looking out of bed, he could scarcely distinguish the transparent window from the opaque walls of his chamber. He was endeavouring to pierce the darkness with his ferret eyes, when the chimes of a neighbouring church struck the four quarters. So he listened for the hour. To his great astonishment the heavy bell went on from six to seven, and from seven to eight, and regularly up to twelve; then stopped. Twelve! It was past two when he went to bed. The clock was wrong. An icicle must have got into the works. Twelve! He touched the spring of his repeater, to correct this most preposterous clock. Its rapid little pulse beat twelve: and stopped.&lt;/p&gt;
&lt;p class="format" lang="en"&gt;WHEN Scrooge awoke, it was so dark, that looking out of bed, he could scarcely distinguish the transparent window from the opaque walls of his chamber. He was endeavouring to pierce the darkness with his ferret eyes, when the chimes of a neighbouring church struck the four quarters. So he listened for the hour. To his great astonishment the heavy bell went on from six to seven, and from seven to eight, and regularly up to twelve; then stopped. Twelve! It was past two when he went to bed. The clock was wrong. An icicle must have got into the works. Twelve! He touched the spring of his repeater, to correct this most preposterous clock. Its rapid little pulse beat twelve: and stopped.&lt;/p&gt;
</pre>

<p>CSS :</p>

<pre class="brush: css">.format {
  /* On « tire » la première ligne sur
     une distance de 2em */
  text-indent: -2em;

  /* Il faut compenser l'indentation négative
     si on veut éviter que du texte saute et
     pour garder l'ensemble du texte dans la
     boîte de l'élément */
  padding-left: 2em;

  /* Le texte est aligné par rapport aux deux
     bords et l'espace entre les mots est ajusté
     pour le remplissage de la ligne */
  text-align: justify;

  /* La dernière ligne de texte du bloc est
     centrée*/
  -moz-text-align-last: center;
       text-align-last: center;

  /* Plutôt que le saut de ligne se fasse entre deux mots,
     il peut être fait en découpant un mot, selon les règles
     de la langue utilisée. Cela permet de découper le texte
     clairement avec un trait d'union. Si cela ne vous
     importe pas, vous pouvez utiliser word-break ou
     word-wrap à la place  */
  -webkit-hyphens: auto;
     -moz-hyphens: auto;
      -ms-hyphens: auto;
          hyphens: auto;
}</pre>

<div class="note">
<p><strong>Note :</strong> Comme vous avez pu le voir, certaines propriétés sont écrites plusieurs fois avec un préfixe. Certaines propriétés sont expérimentales pour certains navigateurs et doivent donc être préfixées, c'est une bonne pratique que de les utiliser préfixées tant qu'elles sont expérimentales, tout en fournissant le nom de la propriété standard à la fin afin d'avoir la meilleure rétrocompatibilité possible.</p>
</div>

<p>Le résultat obtenu sera :</p>

<p>{{EmbedLiveSample('La_disposition_du_texte', '100%', '350')}}</p>

<div class="note">
<p><strong>Note :</strong> L'astuce utilisée pour compenser l'indentation négative est une astuce assez courante. Tout propriété qui accepte une longueur peut accepter une valeur négative. En jouant avec les valeurs négatives et en les compensant avec d'autres propriétés, il est possible de produire des effets visuels très intéressants, notamment quand on manipule les propriétés liées au modèle de boîte.</p>
</div>

<h3 id="Le_flottement">Le flottement</h3>

<p>C'est une chose que de gérer du texte mais on va également vouloir positionner une boîte dans le document. Pour commencer, il faut gérer les boîtes flottantes. Les boîtes flottantes sont toujours attachées au flux global de texte mais le texte « coulera » autour. Si cela vous paraît, prenons un exemple.</p>

<h4 id="Le_flottement_simple">Le flottement simple</h4>

<p>HTML :</p>

<pre class="brush: html">&lt;div&gt;
  &lt;p class="excerpt"&gt;"Why, it isn't possible," said Scrooge, "that I can have slept through a whole day and far into another night. It isn't possible that anything has happened to the sun, and this is twelve at noon!" &lt;/p&gt;
  &lt;p&gt; The idea being an alarming one, he scrambled out of bed, and groped his way to the window. He was obliged to rub the frost off with the sleeve of his dressing-gown before he could see anything; and could see very little then. All he could make out was, that it was still very foggy and extremely cold, and that there was no noise of people running to and fro, and making a great stir, as there unquestionably would have been if night had beaten off bright day, and taken possession of the world. This was a great relief, because "three days after sight of this First of Exchange pay to Mr. Ebenezer Scrooge or his order," and so forth, would have become a mere United States' security if there were no days to count by.&lt;/p&gt;
&lt;/div&gt;</pre>

<p>CSS :</p>

<pre class="brush: css">.excerpt {
  /* Une boîte flottante agira comme un bloc
     quelle que soit la valeur de display */
  display: block;

  /* La boîte flottera à gauche ce qui signifie
     qu'elle sera sur la partie gauche du bloc
     englobant et que le texte « coulera » sur sa
     droite. */
  float: left;

  /* Il est nécessaire de déclarer une largeur pour
     une boîte flottante. Si on ne le fait pas, la
     largeur sera calculée automatiquement et occupera
     autant d'espace que possible. Cela aurait eu le
     même effet qu'un bloc ordinaire. */
  width: 40%;

  /* On définit une marge à droite et en bas pour éviter
     que le texte qui flotte autour soit collé à celui de
     la boîte */
  margin: 0 1em 1em 0;

  /* On rend la boîte flottante plus visible avec une
     oucleur d'arrière-plan */
  background: lightgrey;

  /* Puisque l'arrière-plan est opaque, on ajoute un écart
     entre le contenu et les bords de la boîte */
  padding: 1em;
}</pre>

<p>Ces éléments permettront d'avoir :</p>

<p>{{ EmbedLiveSample('Le_flottement_simple', '100%', '280') }}</p>

<h4 id="Organiser_une_disposition_avec_le_flottement">Organiser une disposition avec le flottement</h4>

<p>La méthode précédente est simple et illustre comment manipuler le flux. Il est possible d'aller plus loin et d'organiser l'ensemble de la disposition du document avec. Les boîtes flottantes dans une direction donnée s'empilent horizontalement, cela permet de créer très facilement des lignes de boîtes. Les boîtes qui sont des blocs forment s'empilent elles sous forme de colonnes.</p>

<p>Là encore, illustrons le point avec un exemple.</p>

<p>HTML :</p>

<pre class="brush: html">&lt;div class="layout"&gt;
  &lt;div class="row"&gt;
    &lt;p class="cell size50"&gt;Scrooge went to bed again, and thought, and thought, and thought it over and over and over, and could make nothing of it. The more he thought, the more perplexed he was; and the more he endeavoured not to think, the more he thought.&lt;/p&gt;
    &lt;p class="cell size50"&gt;Marley's Ghost bothered him exceedingly. Every time he resolved within himself, after mature inquiry, that it was all a dream, his mind flew back again, like a strong spring released, to its first position, and presented the same problem to be worked all through, "Was it a dream or not?"&lt;/p&gt;
  &lt;/div&gt;
  &lt;div class="row"&gt;
    &lt;p class="cell size100"&gt;Scrooge lay in this state until the chime had gone three quarters more, when he remembered, on a sudden, that the Ghost had warned him of a visitation when the bell tolled one. He resolved to lie awake until the hour was passed; and, considering that he could no more go to sleep than go to Heaven, this was perhaps the wisest resolution in his power.&lt;/p&gt;
  &lt;/div&gt;
  &lt;div class="row"&gt;
    &lt;p class="cell size33"&gt;The quarter was so long, that he was more than once convinced he must have sunk into a doze unconsciously, and missed the clock. At length it broke upon his listening ear.&lt;/p&gt;
    &lt;p class="cell size33"&gt;
      "Ding, dong!"&lt;br&gt;
      "A quarter past," said Scrooge, counting.&lt;br&gt;
      "Ding, dong!"&lt;br&gt;
      "Half-past!" said Scrooge.&lt;br&gt;
      "Ding, dong!"&lt;br&gt;
      "A quarter to it," said Scrooge.
    &lt;/p&gt;
    &lt;p class="cell size33"&gt;
      "Ding, dong!"&lt;br&gt;
      "The hour itself," said Scrooge, triumphantly, "and nothing else!"&lt;br&gt;
      He spoke before the hour bell sounded, which it now did with a deep, dull, hollow, melancholy ONE. Light flashed up in the room upon the instant, and the curtains of his bed were drawn.
    &lt;/p&gt;
  &lt;/div&gt;
&lt;/div&gt;</pre>

<p>CSS :</p>

<pre class="brush: css">/* Le conteneur principal pour la disposition */
.layout {
  /* On ajoute un arrière-plan pour le rendre
     visible */
  background: lightgrey;

  /* On ajoute un léger interstice pour harmoniser
     la distance entre le contenu des cellules et
     la bordure du conteneur principal */
  padding   : 0.5em;
}

/* Ici, on empêche les boîtes flottantes de
   dépasser d'un conteneur (ce qui peut arriver
   si le conteneur est vide car il aura alors
   une hauteur nulle). Avec overflow
   hidden, la boîte flottante ne passera pas à
   travers et la boîte parente sera agrandie
   pour éviter un dépassement de la boîte.  */
.row {
  overflow: hidden;
}

/* Chaque cellule sera une boîte flottante à gauche */
.cell {
  float : left;

  /* On ajoute du padding pour créer un écart visuel
     entre les cellules */
  padding   : 0.5em;

  /* Étant donné qu'on ajoute du padding, il faut
     s'assurer que cela ne touchera pas la largeur
     de la boîte. */
  box-sizing: border-box;

  /* Comme la marge ne peut pas être contrôlée par
     la propriété box-sizing, on s'assure d'en
     avoir aucune appliquée ici. */
  margin    : 0;
}

/* Voici les tailles appliquées aux boîtes */
.size33  { width:  33%; } /* Pas un tiers mais presque */
.size50  { width:  50%; } /* Une moitié */
.size100 { width: 100%; } /* Une ligne */</pre>

<p>Cela donnera le résultat suivant :</p>

<p>{{EmbedLiveSample('Organiser_une_disposition_avec_le_flottement', '100%', '520')}}</p>

<p>De nombreux <em>frameworks</em> CSS utilisent ces méthodes de boîtes flottantes. C'est une technique robuste et connue mais qui a ses limites : tout doit être géré avec le flux, il n'est pas possible de gérer un ordre arbitraire pour les boîtes, de gérer des dimensionnements variables et il est impossible de centrer verticalement des éléments. Nous vous encourageons à poursuivre la réflexion, <a href="http://www.positioniseverything.net/articles/onetruelayout/">les boîtes flottantes sont étudiées depuis longtemps (article en anglais)</a> et constituent une des solutions les plus robustes pour gérer une disposition simple, compatible avec les navigateurs historiques.</p>

<p>Si vous souhaitez en savoir plus sur les subtilités des boîtes flottantes, nous vous invitons à lire <em><a href="https://css-tricks.com/all-about-floats/">All about float</a></em> (en anglais) par Chris Coyer.</p>

<h3 id="Le_positionnement">Le positionnement</h3>

<p>Si les boîtes flottantes font partie du flux, il existe un autre mécanisme qui permet d'organiser une disposition en extrayant les boîtes du flux : le positionnement CSS. Le positionnement fonctionne en définissant un contexte de positionnement grâce à la propriété {{cssxref("position")}} puis en permettant aux boites de se positionner en utilisant les propriétés {{cssxref("top")}}, {{cssxref("left")}}, {{cssxref("right")}}, and {{cssxref("bottom")}}.</p>

<p>La propriété {{cssxref("position")}} peut prendre quatre valeurs différentes :</p>

<dl>
 <dt><code>static</code></dt>
 <dd>La valeur par défaut pour tous les éléments : ils font partie du flux et on ne définit pas un contexte de positionnement spécifique.</dd>
 <dt><code>relative</code></dt>
 <dd>Avec cette valeur, les éléments font toujours partie du flux mais peuvent être déplacés visuellement avec les valeurs des propriétés {{cssxref("top")}}, {{cssxref("left")}}, {{cssxref("right")}} et {{cssxref("bottom")}}. Ces propriétés définissent le contexte de positionnement des éléments fils.</dd>
 <dt><code>absolute</code></dt>
 <dd>Avec cette valeur, les éléments ne sont plus placés dans le flux et ne l'influencent plus. La position du bloc est définie avec les propriétés {{cssxref("top")}}, {{cssxref("left")}}, {{cssxref("right")}} et {{cssxref("bottom")}}. Le point de position 0,0  représente le coin en haut à gauche de l'élément parent le plus proche qui définit un contexte de positionnement autre que <code>static</code>. S'il n'y a pas de tel parent, la position 0,0 représente le coin en haut à gauche du document.</dd>
 <dt><code>fixed</code></dt>
 <dd>Avec cette valeur, les éléments ne sont plus placés dans le flux et ne l'influencent plus. La position du bloc est définie avec les propriétés {{cssxref("top")}}, {{cssxref("left")}}, {{cssxref("right")}}, and {{cssxref("bottom")}}. La position 0,0 représente le coin en haut à gauche de fenêtre du navigateur ({{Glossary("viewport")}}).</dd>
</dl>

<p>Les boîtes positionnées de cette façon peuvent s'empiler les unes sur les autres. Dans ce cas, il est possible de changer l'ordre d'empilement grâce à la propriété {{cssxref("z-index")}}.</p>

<p>Une dernière fois, prenons un exemple pour illustrer le concept.</p>

<p>Le code HTML pour le document sera :</p>

<pre class="brush: html">&lt;p&gt;
  The curtains of his bed were drawn aside, I tell you, by a hand. Not the curtains at his feet, nor the curtains at his back, but those to which his face was addressed. The curtains of his bed were drawn aside; and Scrooge, starting up into a half-recumbent attitude, found himself face to face with the unearthly visitor who drew them: as close to it as I am now to you, and I am standing in the spirit at your elbow.
  &lt;span class="topleft"&gt;1&lt;/span&gt;
&lt;/p&gt;
&lt;p class="relative"&gt;
  It was a strange figure--like a child: yet not so like a child as like an old man, viewed through some supernatural medium, which gave him the appearance of having receded from the view, and being diminished to a child's proportion. Its hair, which hung about its neck and down its back, was white as if with age; and yet the face had not a wrinkle in it, and the tenderest bloom was on the skin. The arms were very long and muscular; the hands the same, as if its hold were of uncommon strength. Its legs and feet, most delicately formed, were, like those upper members, bare. It wore a tunic of the purest white; and round its waist was bound a lustrous belt, the sheen of which was beautiful. It held a branch of fresh green holly in its hand; and, in singular contradiction of that wintry emblem, had its dress trimmed with summer flowers. But the strangest thing about it was, that from the crown of its head there sprung a bright clear jet of light, by which all this was visible; and which was doubtless the occasion of its using, in its duller moments, a great extinguisher for a cap, which it now held under its arm.
  &lt;span class="topleft"&gt;2&lt;/span&gt;
  &lt;span class="stackdown"&gt;3&lt;/span&gt;
  &lt;span class="stackup"&gt;4&lt;/span&gt;
&lt;/p&gt;</pre>

<p>La feuille de style CSS sera :</p>

<pre class="brush: css">p {
  margin: 1em
}

span {
  font       : 2em sans-serif;
  width      : 6rem;

  /* Avoir la hauteur de l'élément et la hauteur
     de la ligne avec la même valeur permet de
     centrer verticalement une ligne de texte. */
  height     : 6rem;
  line-height: 6rem;

  text-align : center;
  background : rgba(0, 255, 255, 0.8);
}

.relative {
  position: relative;
}

/* Tous les éléments de la classe "topleft"
   sont positionnés dans le coin en haut à
   gauche de leur parent dans le contexte
   de positionnement */
.topleft {
  position: absolute;
  top     : 0;
  left    : 0;
}

.stackup {
  position: absolute;
  top     : 37%;
  left    : 62%;

  /* Tous les éléments de la classe "stackup"
     sont placés au-dessus des éléments dont
     le z-index est inférieur à 2 dans le même
     contexte de positionnement. */
  z-index : 2;
}

.stackdown {
  position: absolute;
  top     : 50%;
  left    : 66%;

  /* Tous les éléments de la classe "stackdown"
     sont placés sous les éléments dont le
     z-index est supérieur à 1 dans le même
     contexte de positionnement. */
  z-index : 1;
}
</pre>

<p>La combinaison de ces deux éléments donnera le résultat suivant :</p>

<p>{{EmbedLiveSample('Le_positionnement', '100%', '400')}}</p>

<p>Bien que le positionnement CSS ne soit pas réellement utile pour complètement organiser une disposition, il est généralement judicieux pour obtenir certains effets liés à la navigation, aux bulles d'informations, etc. C'est un mécanisme que vous rencontrerez fréquemment et nous vous encourageons donc à vous familiariser avec. Parmi les ressources qui existent par ailleurs, nous vous conseillons particulièrement de lire l'article <em><a href="http://alistapart.com/article/css-positioning-101">CSS positioning 101</a></em> (en anglais), de Noah Stokes.</p>

<h2 id="La_suite">La suite</h2>

<p>Le flux, les boîtes flottantes et le positionnement CSS sont les bases qui vous permettront d'approfondir la création d'une disposition en CSS. Suite à cette série d'articles sur les concepts théoriques de CSS, vous connaissez tout ce qu'il faut pour exploiter au mieux CSS. Après ce vernis théorique, vous pouvez aborder <a href="/fr/docs/Apprendre/CSS/Comment">les aspects pratiques de CSS</a>. Si vous souhaitez approfondir les concepts sur la disposition et découvrir les autres mécanismes à ce sujet, vous pouvez consulter les articles sur : les tableaux, <a href="/fr/docs/Web/CSS/Colonnes_CSS3">l'organisation à plusieurs colonnes</a> et <a href="/fr/docs/Web/CSS/CSS_Flexible_Box_Layout/Utilisation_des_flexbox_en_CSS">la disposition avec les boîtes flexibles (<em>flexbox</em>)</a>.</p>

<p>{{PreviousNext("Apprendre/CSS/Les_bases/Le_modèle_de_boîte","Apprendre/CSS/Comment/Mettre_en_forme_du_texte")}}</p>