"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment créer un mixin d'espace réservé dans SCSS/CSS à l'aide de @content et @at-root ?

Comment créer un mixin d'espace réservé dans SCSS/CSS à l'aide de @content et @at-root ?

Publié le 2024-11-19
Parcourir:844

How to Create a Placeholder Mixin in SCSS/CSS Using @content and @at-root?

Mixin d'espace réservé dans SCSS/CSS

Vous êtes confronté à un problème lors de la création d'un mixin d'espace réservé dans Sass en raison de la présence de deux-points et de points-virgules dans les propriétés CSS transmises le mixin.

Pour surmonter ce défi, utilisez la directive @content dans votre mixin :

@mixin placeholder {
  ::-webkit-input-placeholder {@content}
  :-moz-placeholder           {@content}
  ::-moz-placeholder          {@content}
  :-ms-input-placeholder      {@content}  
}

Vous pouvez désormais inclure le mixin comme suit :

@include placeholder {
    font-style: italic;
    color: white;
    font-weight: 100;
}

De plus, Sass 3.4 introduit la directive @at-root, vous permettant d'écrire votre mixin d'une manière qui fonctionne à la fois dans des contextes imbriqués et non imbriqués :

@mixin placeholder {
  @include optional-at-root('::-webkit-input-placeholder') {
    @content;
  }

  @include optional-at-root(':-moz-placeholder') {
    @content;
  }

  @include optional-at-root('::-moz-placeholder') {
    @content;
  }

  @include optional-at-root(':-ms-input-placeholder') {
    @content;
  }
}

En utilisant @at-root en conjonction avec @content, vous vous assurez que votre mixin fonctionne correctement dans tous les scénarios.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3