diff options
Diffstat (limited to 'files/fr/web/css/_doublecolon_before')
-rw-r--r-- | files/fr/web/css/_doublecolon_before/index.md | 182 |
1 files changed, 81 insertions, 101 deletions
diff --git a/files/fr/web/css/_doublecolon_before/index.md b/files/fr/web/css/_doublecolon_before/index.md index 51d962fb43..10fe4f2b16 100644 --- a/files/fr/web/css/_doublecolon_before/index.md +++ b/files/fr/web/css/_doublecolon_before/index.md @@ -1,68 +1,74 @@ --- title: '::before (:before)' -slug: 'Web/CSS/::before' +slug: Web/CSS/::before tags: - CSS - Pseudo-element - Reference -translation_of: 'Web/CSS/::before' +translation_of: Web/CSS/::before --- -<div>{{CSSRef}}</div> +{{CSSRef}} -<p><strong><code>::before</code></strong> crée un <a href="/fr/docs/Web/CSS/Pseudo-éléments">pseudo-élément</a> qui sera le premier enfant de l'élément ciblé. Généralement utilisé pour ajouter du contenu esthétique à un élément via la propriété CSS {{cssxref("content")}}. Par défaut, l'élément créé est de type en-ligne (<em>inline</em>).</p> +**`::before`** crée un [pseudo-élément](/fr/docs/Web/CSS/Pseudo-éléments) qui sera le premier enfant de l'élément ciblé. Généralement utilisé pour ajouter du contenu esthétique à un élément via la propriété CSS {{cssxref("content")}}. Par défaut, l'élément créé est de type en-ligne (_inline_). -<pre class="brush:css no-line-numbers">/* On ajoute un coeur avant les liens */ +```css +/* On ajoute un coeur avant les liens */ a::before { content: "♥"; } -</pre> +``` -<div class="note"> -<p><strong>Note :</strong> Les pseudo-éléments générés par <code>::before</code> et <code>::after</code> sont contenus dans la boîte de mise en forme de l'élément. Aussi, <code>::before</code> et <code>::after</code> ne s'appliquent pas <a href="/fr/docs/Web/CSS/Élément_remplacé">aux éléments remplacés</a> tels que {{HTMLElement("img")}} ou {{HTMLElement("br")}}.</p> -</div> +> **Note :** Les pseudo-éléments générés par `::before` et `::after` sont contenus dans la boîte de mise en forme de l'élément. Aussi, `::before` et `::after` ne s'appliquent pas [aux éléments remplacés](/fr/docs/Web/CSS/Élément_remplacé) tels que {{HTMLElement("img")}} ou {{HTMLElement("br")}}. -<h2 id="Syntaxe">Syntaxe</h2> +## Syntaxe {{csssyntax}} -<p>La notation <code>::before</code> a été introduite par CSS 3 pour différencier les <a href="/fr/docs/Web/CSS/Pseudo-classes">pseudo-classes</a> et les <a href="/fr/docs/Web/CSS/Pseudo-éléments">pseudo-éléments</a>. Les navigateurs acceptent aussi la notation <code>:before </code>introduite par CSS 2.</p> +La notation `::before` a été introduite par CSS 3 pour différencier les [pseudo-classes](/fr/docs/Web/CSS/Pseudo-classes) et les [pseudo-éléments](/fr/docs/Web/CSS/Pseudo-éléments). Les navigateurs acceptent aussi la notation `:before `introduite par CSS 2. -<h2 id="Exemples">Exemples</h2> +## Exemples -<h3 id="Ajouter_des_guillemets">Ajouter des guillemets</h3> +### Ajouter des guillemets -<p>Un exemple simple utilisant les pseudo-éléments pour ajouter des guillemets. Ici nous avons <code>::before</code> et {{cssxref("::after")}} pour effectuer l'insertion.</p> +Un exemple simple utilisant les pseudo-éléments pour ajouter des guillemets. Ici nous avons `::before` et {{cssxref("::after")}} pour effectuer l'insertion. -<h4 id="HTML">HTML</h4> +#### HTML -<pre class="brush: html"><q>Quelques guillemets</q>, dit-il, <q>sont mieux que pas du tout</q></pre> +```html +<q>Quelques guillemets</q>, dit-il, <q>sont mieux que pas du tout</q> +``` -<h4 id="CSS">CSS</h4> +#### CSS -<pre class="brush: css">q::before { +```css +q::before { content: "«"; color: blue; } q::after { content: '»'; color: red; -}</pre> +} +``` -<h4 id="Résultat">Résultat</h4> +#### Résultat -<p>{{EmbedLiveSample('Ajouter_des_guillemets', '500', '50', '')}}</p> +{{EmbedLiveSample('Ajouter_des_guillemets', '500', '50', '')}} -<h3 id="Exemple_décoratif">Exemple décoratif</h3> +### Exemple décoratif -<p>Il est possible de mettre du style à du texte ou des images, dans la propriété {{cssxref("content")}} , quasiment de n'importe quelle manière.</p> +Il est possible de mettre du style à du texte ou des images, dans la propriété {{cssxref("content")}} , quasiment de n'importe quelle manière. -<h4 id="HTML_2">HTML</h4> +#### HTML -<pre class="brush: html"><span class="ribbon">Observez où est placée la boite orange.</span></pre> +```html +<span class="ribbon">Observez où est placée la boite orange.</span> +``` -<h4 id="CSS_2">CSS</h4> +#### CSS -<pre class="brush: css">.ribbon { +```css +.ribbon { background-color: #5BC8F7; } @@ -71,31 +77,34 @@ q::after { background-color: #FFBA10; border-color: black; border-style: dotted; -}</pre> +} +``` -<h4 id="Résultat_2">Résultat</h4> +#### Résultat -<p>{{EmbedLiveSample('Exemple_décoratif', 450, 60)}}</p> +{{EmbedLiveSample('Exemple_décoratif', 450, 60)}} -<h3 id="Liste_de_choses_à_faire">Liste de choses à faire</h3> +### Liste de choses à faire -<p>Dans cet exemple, nous allons créer une simple liste de choses à faire en utilisant les pseudo-éléments. Cette méthode peut être utilisée pour ajouter une petite touche à l'interface utilisateur et améliorer l'expérience utilisateur.</p> +Dans cet exemple, nous allons créer une simple liste de choses à faire en utilisant les pseudo-éléments. Cette méthode peut être utilisée pour ajouter une petite touche à l'interface utilisateur et améliorer l'expérience utilisateur. -<h4 id="HTML_3">HTML</h4> +#### HTML -<pre class="brush: html"><ul> - <li>Acheter du lait</li> - <li>Promener le chien</li> - <li>Faire de l'exercice</li> - <li>Coder</li> - <li>Jouer de la musique</li> - <li>Se reposer</li> -</ul> -</pre> +```html +<ul> + <li>Acheter du lait</li> + <li>Promener le chien</li> + <li>Faire de l'exercice</li> + <li>Coder</li> + <li>Jouer de la musique</li> + <li>Se reposer</li> +</ul> +``` -<h4 id="CSS_3">CSS</h4> +#### CSS -<pre class="brush: css">li { +```css +li { list-style-type: none; position: relative; margin: 1px; @@ -120,68 +129,39 @@ li.done::before { margin-top: -1em; transform: rotate(45deg); width: 0.5em; -}</pre> +} +``` -<h4 id="JavaScript">JavaScript</h4> +#### JavaScript -<pre class="brush: js">var list = document.querySelector('ul'); +```js +var list = document.querySelector('ul'); list.addEventListener('click', function(ev) { if( ev.target.tagName === 'LI') { ev.target.classList.toggle('done'); } }, false); -</pre> - -<h4 id="Résultat_3">Résultat</h4> - -<p>{{EmbedLiveSample('Liste_de_choses_à_faire', '400', '300', '')}}</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('CSS4 Pseudo-Elements', '#selectordef-before', '::before')}}</td> - <td>{{Spec2('CSS4 Pseudo-Elements')}}</td> - <td>Pas de modification significative depuis la spécification précédente.</td> - </tr> - <tr> - <td>{{Specname("CSS3 Transitions", "#animatable-properties", "")}}</td> - <td>{{Spec2("CSS3 Transitions")}}</td> - <td>Les transitions peuvent être appliquées sur les propriétés de ce pseudo-élément.</td> - </tr> - <tr> - <td>{{Specname("CSS3 Animations", "", "")}}</td> - <td>{{Spec2("CSS3 Animations")}}</td> - <td>Les animations peuvent être appliquées sur les propriétés de ce pseudo-élément.</td> - </tr> - <tr> - <td>{{SpecName('CSS3 Selectors', '#gen-content', '::before')}}</td> - <td>{{Spec2('CSS3 Selectors')}}</td> - <td>Introduction de la syntaxe avec les deux deux-points.</td> - </tr> - <tr> - <td>{{SpecName('CSS2.1', 'generate.html#before-after-content', '::before')}}</td> - <td>{{Spec2('CSS2.1')}}</td> - <td>Définition initiale avec une seule fois le caractère deux-points.</td> - </tr> - </tbody> -</table> - -<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2> - -<p>{{Compat("css.selectors.before")}}</p> - -<h2 id="Voir_aussi">Voir aussi</h2> +``` -<ul> - <li>{{cssxref("::after")}}</li> - <li>{{cssxref("content")}}</li> -</ul> +#### Résultat + +{{EmbedLiveSample('Liste_de_choses_à_faire', '400', '300', '')}} + +## Spécifications + +| Spécification | État | Commentaires | +| ------------------------------------------------------------------------------------------------ | -------------------------------------------- | -------------------------------------------------------------------------------- | +| {{SpecName('CSS4 Pseudo-Elements', '#selectordef-before', '::before')}} | {{Spec2('CSS4 Pseudo-Elements')}} | Pas de modification significative depuis la spécification précédente. | +| {{Specname("CSS3 Transitions", "#animatable-properties", "")}} | {{Spec2("CSS3 Transitions")}} | Les transitions peuvent être appliquées sur les propriétés de ce pseudo-élément. | +| {{Specname("CSS3 Animations", "", "")}} | {{Spec2("CSS3 Animations")}} | Les animations peuvent être appliquées sur les propriétés de ce pseudo-élément. | +| {{SpecName('CSS3 Selectors', '#gen-content', '::before')}} | {{Spec2('CSS3 Selectors')}} | Introduction de la syntaxe avec les deux deux-points. | +| {{SpecName('CSS2.1', 'generate.html#before-after-content', '::before')}} | {{Spec2('CSS2.1')}} | Définition initiale avec une seule fois le caractère deux-points. | + +## Compatibilité des navigateurs + +{{Compat("css.selectors.before")}} + +## Voir aussi + +- {{cssxref("::after")}} +- {{cssxref("content")}} |