Maison >interface Web >tutoriel CSS >Qu'est-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

Qu'est-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

青灯夜游
青灯夜游avant
2021-07-06 10:44:533694parcourir

CSS : la pseudo-classe placeholder-shown est un objet spécifiquement utilisé pour déterminer si un élément affiche un espace réservé. Il est principalement utilisé pour vérifier si le contenu d'entrée est vide. Cet article vous guidera à travers : la pseudo-classe affichée par un espace réservé et vous présentera en détail son fonctionnement.

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

Utilisez cette pseudo-classe pour styliser l'entrée qui affiche actuellement du texte d'espace réservé, en d'autres termes, l'utilisateur ne tape rien dans la zone de texte

Appliquez un style dynamique selon que votre entrée est vide ou non. Bon

input:placeholder-shown {
  border-color: pink;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

Comment ça marche ?

:placeholder-show est une pseudo-classe CSS qui vous permet d'appliquer des styles à <input> ou <textarea qui ont du texte d r>. <code>:placeholder-show 是CSS伪类,可让您将样式应用于具有占位符文本的 <input><textarea></textarea>

<input placeholder="placeholder text" />
<textarea placeholder="placeholder text"></textarea>

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

结果:

  • 如果显示占位符,则为粉红色,表示用户未输入任何内容
  • 如果未显示任何占位符,则为黑色,表示用户已键入内容

:placeholder-showd必须具有占位符

如果元素没有占位符文本,则此选择器将不起作用。

<input /><!-- 没有占位符 -->

<!-- 这也被视为没有占位符文本 -->
<input placeholder="" />
input:placeholder-shown {
  border-color: pink;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

:placeholder-shown vs ::placeholder

因此,我们可以使用 :placeholder-shown 设置输入元素的样式。

input:placeholder-shown {
  border: 1px solid pink;
  background: yellow;
  color: green;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

☝️嗯...注意到有些奇怪——我们将颜色设置为:绿色,但没有用。好吧,这是因为 :placeholder-shown 只针对输入本身。但是对于实际的占位符文本,您必须使用伪元素 ::placeholder

input::placeholder {
  color: green;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

但是!当我在处理这个问题时,我注意到还有一些其他属性,如果在 :placeholder-shown 级别应用,将会影响到占位符文本。

input:placeholder-shown {
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: 5px;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

现在,我真的不知道为什么会发生这种情况,也许是因为这些属性被占位符继承了。

:placeholder-shown vs :empty

尽管 :placeholder-shown 是专门用于确定元素是否显示占位符的。实际上,我们可以使用它来检查输入是否为空(当然,假设所有输入都有一个占位符)。因此,也许您的下一个问题是,我们不能使用CSS empty吗?好吧,让我们检查一下

<input value="not empty">
<input><!-- empty -->
input:empty {
  border: 1px solid pink;
}

input {
  border: 1px solid black;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

期待:

  • 如果为空则为粉红色
  • 如果不为空为黑色

嗯...从这里开始,您可能会认为 :empty 似乎在起作用,因为我们看到的是粉红色边框。但这实际上不起作用

粉红色显示的原因是因为伪类增加了特异性,类似于类选择器(即 .form-input)比类型选择器(即 input)具有更高的特异性。高特异性选择器将始终覆盖低特异性设置的样式。

这是判决!不要使用 :empty 检查输入元素是否为空

如何在没有占位符的情况下检查输入是否为空?

好了,所以我们检查输入是否为空的唯一方法是使用 :placeholder-shown。但是,如果我们的输入元素没有占位符,会发生什么情况?好吧,这是一个聪明的方法!传入一个空字符串 " "

<input placeholder=" "><!--  传递空字符串 -->
input:placeholder-shown {
  border-color: pink;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

与其他选择器组合

所以,我们可以针对显示占位符文字的输入元素,这很酷。换句话说,如果显示了占位符文本,那么一定意味着该元素是空的。利用这些知识,我们可以将这个伪类与其他选择器结合起来,做一些非常整洁的事情!让我们来看看。

反向 :placeholder-shown:not

我们可以使用 :not

<input placeholder="placeholder" value="not empty" />

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜 Résultat : 🎜
  • Si l'espace réservé est affiché, il est rose, indiquant que l'utilisateur n'a rien tapé.
  • Si aucun espace réservé n'est affiché, il est noir, indiquant que l'utilisateur a tapé. quelque chose

🎜:placeholder-showd doit avoir un espace réservé 🎜

🎜Ce sélecteur ne fonctionnera pas si l'élément n'a pas de texte d'espace réservé. 🎜
input:not(:placeholder) {
  border-color: green;
}
rrree🎜Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜:placeholder-shown vs ::placeholder🎜🎜Par conséquent, nous pouvons utiliser :placeholder-shown pour définir le style d’élément d’entrée. 🎜
<input name="name" placeholder="Type name..." />
<label for="name">NAME</label>
🎜Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜 ☝️Hmm... j'ai remarqué quelque chose d'étrange - nous avons réglé la couleur sur : vert, mais cela n'a pas fonctionné. Eh bien, c'est parce que :placeholder-shown ne fonctionne que sur l'entrée elle-même. Mais pour le texte d'espace réservé réel, vous devez utiliser le pseudo-élément ::placeholder. 🎜
label {
  display: none;
  position: absolute;
  top: 0;
}

input:not(:placeholder-shown) + label {
  display: block;
}
🎜Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜 mais! Pendant que je travaillais sur ce problème, j'ai remarqué qu'il existe quelques autres propriétés qui affecteraient le texte de l'espace réservé si elles étaient appliquées au niveau :placeholder-shown. 🎜rrreee🎜Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜 Maintenant, je ne sais pas vraiment pourquoi cela se produit, peut-être parce que les propriétés sont héritées des espaces réservés. 🎜

🎜:placeholder-shown vs :empty🎜

🎜Bien que :placeholder-shown soit spécifiquement utilisé pour déterminer le element Indique s'il faut afficher des espaces réservés. En fait, nous pouvons l'utiliser pour vérifier si l'entrée est vide (en supposant, bien sûr, que toutes les entrées ont un espace réservé). Alors peut-être que votre prochaine question est la suivante : ne pouvons-nous pas utiliser CSS vide ? Eh bien, voyons ça🎜rrreeerrreee🎜8 . png🎜🎜Attention : 🎜
  • Rose si vide
  • Noir si pas vide
🎜Hmm... à partir de là, vous pourriez penser que :empty fonctionne car nous voyons une bordure rose. Mais cela ne fonctionne pas réellement 🎜🎜La raison pour laquelle il est affiché en rose est que les pseudo-classes ajoutent une spécificité, similaire aux sélecteurs de classe (c'est-à-dire .form-input) qu'aux sélecteurs de type (c'est-à-dire input ) a une spécificité plus élevée. Les sélecteurs à haute spécificité remplaceront toujours les styles définis par une faible spécificité. 🎜🎜Voici le verdict ! N'utilisez pas :empty pour vérifier si l'élément d'entrée est vide 🎜

🎜Comment vérifier si l'entrée est vide sans espace réservé ? 🎜

🎜D'accord, donc la seule façon de vérifier si l'entrée est vide est d'utiliser :placeholder-shown. Mais que se passe-t-il si nos éléments d'entrée n'ont pas d'espace réservé ? Eh bien, c'est une approche intelligente ! Passez une chaîne vide " ". 🎜rrreeerrreee🎜Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?🎜🎜 🎜Combiné avec d'autres sélecteurs🎜🎜🎜Ainsi, nous pouvons cibler les éléments d'entrée qui affichent du texte d'espace réservé, ce qui est cool. En d’autres termes, si du texte d’espace réservé est affiché, cela doit signifier que l’élément est vide. En utilisant ces connaissances, nous pouvons combiner cette pseudo-classe avec d’autres sélecteurs et faire des choses vraiment intéressantes ! Voyons. 🎜

🎜Inversez :placeholder-shown en :not🎜

🎜Nous pouvons utiliser la pseudo-classe :not pour fais-le quelque chose de contraire. Ici, nous pouvons effectuer des opérations cibles lorsque l'entrée n'est pas vide. 🎜
<input placeholder="placeholder" value="not empty" />
input:not(:placeholder) {
  border-color: green;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

结果:

  • 绿色,如果不为空,则表示用户已经输入了一些内容。
  • 如果为空,则为黑色

浮动标签

使用占位符而不使用标签的问题之一就是无障碍,因为一旦你在打字的时候,占位符文字就没有了,这可能会导致用户的困惑。一个真正好的解决方案是浮动标签。最初,占位符文本显示时没有标签,而一旦用户开始输入,标签就会出现。这样一来,你仍然可以在不影响用户体验和可访问性的前提下,保持表单的简洁性。双赢

而这是可以用纯CSS实现的,我们只需要将 placeholder-shown:not+ 结合起来就可以了。这是一个超级简化版的浮动标签。

<input name="name" placeholder="Type name..." />
<label for="name">NAME</label>
label {
  display: none;
  position: absolute;
  top: 0;
}

input:not(:placeholder-shown) + label {
  display: block;
}

Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

浏览器支持

:placeholder-shown 的支持非常好!这包括Internet Explorer(是的,我和你一样惊讶)。但是,对于IE,你需要使用非标准名称 :-ms-input-placeholder

1Quest-ce que :placeholder-shown en CSS ? Comment ça marche ? A quoi ça sert ?

本文转载自:https://segmentfault.com/a/1190000039928413

作者:杜尼卜

更多编程相关知识,请访问:编程入门!!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer