blob: 336d6c6fad2215c8008043ff99e9db0f227deb09 (
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
|
---
title: ':first'
slug: 'Web/CSS/:first'
tags:
- CSS
- Pseudo-classe
- Reference
translation_of: 'Web/CSS/:first'
---
<div>{{CSSRef}}</div>
<p>La pseudo-classe <strong><code>:first</code></strong>, liée à la règle @ {{cssxref("@page")}} décrit la mise en forme de la première page lors de l'impression d'un document. ( voir {{cssxref(":first-child")}} pour le premier élément d'un noeud )</p>
<pre class="brush: css no-line-numbers notranslate">/* Cible le contenu de la première page */
/* lorsqu'on imprime */
@page :first {
margin-left: 50%;
margin-top: 50%;
}</pre>
<p>Seul un sous-ensemble restreint de propriétés peut être modifié via cette pseudo-classe :</p>
<ul>
<li>Les propriétés liées aux marges : {{cssxref("margin")}}</li>
<li>Les propriétés liées aux lignes veuves et orphelines : {{cssxref("orphans")}} et {{cssxref("widows")}}</li>
<li>Les propriétés liées aux sauts de page : {{cssxref("page-break")}}</li>
</ul>
<p>De plus, seules <a href="/fr/docs/Web/CSS/length#Unités_de_longueur_absolues">les unités absolues</a> peuvent être utilisées pour les marges.</p>
<h2 id="Syntaxe">Syntaxe</h2>
<pre class="syntaxbox notranslate">{{csssyntax}}</pre>
<h2 id="Exemples">Exemples</h2>
<h3 id="CSS">CSS</h3>
<pre class="brush: css notranslate">@page :first {
margin-left: 50%;
margin-top: 50%;
}
p {
page-break-after: always;
}</pre>
<h3 id="HTML">HTML</h3>
<pre class="brush: html notranslate"><p>Première page.</p>
<p>Deuxième page.</p>
<button>Imprimer</button></pre>
<h3 id="JavaScript">JavaScript</h3>
<pre class="brush: js notranslate">document.querySelector("button").addEventListener('click', () => {
window.print();
});</pre>
<p>Appuyez sur le bouton "Imprimer!" pour imprimer l'exemple. Les mots sur la première page doivent être quelque part autour du centre, tandis que les autres pages auront leur contenu à la position par défaut.</p>
<p>{{EmbedLiveSample("Exemples","80%","150px")}}</p>
<h2 id="Spécifications">Spécifications</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Spécification</th>
<th scope="col">État</th>
<th scope="col">Commentaires</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName('CSS3 Paged Media', '#left-right-first', ':first')}}</td>
<td>{{Spec2('CSS3 Paged Media')}}</td>
<td>Aucune modification.</td>
</tr>
<tr>
<td>{{SpecName('CSS2.1', 'page.html#page-selectors', ':first')}}</td>
<td>{{Spec2('CSS2.1')}}</td>
<td>Définition initiale.</td>
</tr>
</tbody>
</table>
<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2>
<div class="hidden">Ce tableau de compatibilité a été généré à partir de données structurées. Si vous souhaitez contribuer à ces données, n'hésitez pas à envoyer une <em>pull request</em> sur <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a>.</div>
<p>{{Compat("css.selectors.first")}}</p>
<h2 id="Voir_aussi">Voir aussi</h2>
<ul>
<li>{{cssxref("@page")}}</li>
<li>{{cssxref(":left")}}</li>
<li>{{cssxref(":right")}}</li>
</ul>
|