diff --git a/files/fr/web/css/subsequent-sibling_combinator/index.md b/files/fr/web/css/subsequent-sibling_combinator/index.md index 696dd4b7bb8081..9957609e266300 100644 --- a/files/fr/web/css/subsequent-sibling_combinator/index.md +++ b/files/fr/web/css/subsequent-sibling_combinator/index.md @@ -1,15 +1,17 @@ --- -title: Sélecteurs de voisins généraux +title: Combinateur de voisins généraux slug: Web/CSS/Subsequent-sibling_combinator +l10n: + sourceCommit: bb652aaf3e38f3c7fef970a62f813047dffac879 --- {{CSSRef("Selectors")}} -Le combinateur `~` permet de séparer deux sélecteurs et de cibler un élément si celui-ci correspond au second sélecteur et est précédé (mais pas forcément voisin immédiat) d'un autre élément correspondant au premier sélecteur qui partage le même parent. Les deux éléments sont des fils d'un même parent {{domxref("Element")}}, voisins immédiats ou pas. +Le **combinateur de voisins généraux** (`~`) permet de séparer deux sélecteurs et de cibler _toutes les instances_ du deuxième élément qui suivent le premier (mais n'étant pas forcément voisin immédiat) et qui partagent le même élément parent. ```css -/* Parmi tous les éléments , cibler tous - éléments

qui les suivent. */ +/* Parmi tous les éléments , cible tous éléments

+ qui les suivent. */ img ~ p { color: red; } @@ -17,13 +19,38 @@ img ~ p { ## Syntaxe -``` +```css-nolint +/* L'espace entre la tilde (~) est optionnel mais est recommendé. */ premier_element ~ second_element { propriétés de style } ``` ## Exemples -### CSS +### Utilisation du combinateur avec des sélecteurs simples + +This example shows the use of the `~` combinator when both the selectors are simple selectors (`p` and `span`). + +```html +

+ Il n'est pas rouge parce qu'il apparaît avant tout paragraphe. +

Voici un paragraphe.

+ Voici un extrait de code. + + Ce span est rouge parce qu'il apparaît après le paragraphe, + même s'il y a d'autres nœuds entre les deux. + +

Quoi qu'il en soit, gardez le sourire.

+

Rêver en grand

+ + Quel que soit le nombre ou le type de nœuds intermédiaires, + tous les span issues du même parent après un paragraphe + sont rouges. + +
+ + Ce span n'est pas rouge car il ne partage pas de parent avec un paragraphe. + +``` ```css p ~ span { @@ -31,20 +58,43 @@ p ~ span { } ``` -### HTML +### Utilisation du combinateur avec des sélecteurs complexes + +Cet exemple contient deux [sélecteurs complexes](/fr/docs/Web/CSS/CSS_selectors/Selector_structure#selecteur_complexe), tous deux utilisant le combinateur de voisins généraux : `.monTexte p ~ span` et `.monTexte p ~ .monTexte span`. + +- Le premier sélecteur complexe, `.monTexte p ~ span`, correspond à tous les `span` qui viennent après un paragraphe _si_ le span et le paragraphe partagent le même parent **et** ce parent ou un parent _plus haut_ de ce parent a la classe `.monTexte`. +- Le second sélecteur complexe, `.monTexte p ~ .monTexte span`, correspond à toutes les `span` qui sont un descendant de l'élément parent avec la classe `.monTexte` _si_ cet élément est un voisin du paragraphe mentionné précédemment. + +L'exemple ci-dessous montre que l'élément cible du sélecteur complexe doit partager le même parent que l'élément initial du sélecteur complexe. ```html -Ici, ce n'est pas rouge. -

Voici un paragraphe.

-Un peu de code. -Et un autre span. -Encore du code -Ici aussi, c'est rouge +

Rêver en grand

+Et encore une fois, il s'agit d'une zone rouge ! +
+

Voici un autre paragraphe.

+ Un span bleu +
+ Un span vert +
+
``` -### Résultat +```css +.monTexte p ~ span { + color: blue; +} + +.monTexte p ~ .monTexte span { + color: green; +} +``` + +{{EmbedLiveSample("Utilisation du combinateur avec des sélecteurs complexes", "auto", 200)}} + +Dans le HTML ci-dessus, les deux voisins de `.monTexte p` sont `span` et `.monTexte`. Le `span` vert est un descendant de la classe `.monTexte`, qui est un voisin de `p`. -{{EmbedLiveSample('Exemples', 280, 120)}} +- Lorsque la cible du sélecteur est `span`, l'élément `span` qui est un voisin de `p` est sélectionné. L'élément `p` est un descendant de `.monTexte`, tout comme ses voisins `span`. +- Dans `.monTexte p ~ .monTexte span`, la cible du sélecteur est `span` qui est un descendant de `.monTexte`. Dans ce cas, `span` est sélectionné si `.monTexte` est un voisin de `p` ; essentiellement, les deux sont imbriqués dans un parent de `.monTexte`. ## Spécifications @@ -56,4 +106,4 @@ p ~ span { ## Voir aussi -- [Sélecteur de voisin direct](/fr/docs/Web/CSS/Sélecteur_de_voisin_direct) +- [Sélecteur de voisin direct](/fr/docs/Web/CSS/Next-sibling_combinator)