Heim >Web-Frontend >CSS-Tutorial >Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

青灯夜游
青灯夜游nach vorne
2021-01-14 18:49:132377Durchsuche

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

(Teilen von Lernvideos: css-Video-Tutorial)

Im Allgemeinen verwenden wir häufig den Pseudoklassenselektor placeholder, um den Standardstil und die Kopie zu ändern, und haben plötzlich placeholder gefunden -shownPseudoklassenselektor, die offiziellere Erklärung lautet: placeholder伪类选择器用来修改默认样式及文案,忽然发现placeholder-shown伪类选择器,比较官方的解释是

CSS伪类表示任何显示占位符文本的form元素。

简单来说就是当输入框的placeholder内容显示的时候,输入框干嘛干嘛。

兼容性如下,在移动端没什么问题

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

placeholder-show是如何工作的?

:placeholder-shown CSS 伪类 在 <input><textarea></textarea> 元素显示 placeholder text 时生效,简单的说就是 placeholder 有值才生效,如下所示:

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

// css 
input:placeholder-shown, textarea:placeholder-shown{ 
  border:1px solid pink;
}

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

如果 placeholder 为空 placeholder-show 就没效果了:

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

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

:placeholder-shown vs ::placeholder

我们可以使用:placeholder-shown设置input元素的样式。

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

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

注意一些奇怪的问题-我们设置 color: green,但没有作用用。这是因为:placeholder-shown仅会针对input本身。对于实际的占位符文本,必须使用伪元素::placeholder

input::placeholder {
  color: green;
}

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

我注意到有一些其他的属性,如果应用::placeholder-shown,也会影响placeholder的样式。

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

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

我也不知道这是啥情况,也许是因为这些属性被placeholder继承了,如果你知道原因,欢迎留言告诉我一下,谢谢。

:placeholder-shown vs :empty

:placeholder-shown是专门用于确定元素是否显示占位符的对象,我们主要使用它来检查input 内容是否为空(假设所有的input都有一个占位符)。 这里你可能会想,使用 empty 也是可以的吧?我们来看看。

// html
<input value="not empty">
<input><!-- empty -->

// css
input:empty {
  border: 1px solid pink;
}

input {
  border: 1px solid black;
}

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

这里看似empty起作用了,因为我们看到的是粉红色边框,但这实际上不起作用

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

所以我们可以这样说:不要使用:empty检查输入元素是否为空。

如果检查 input 内容是否为空(在没有点位符的情况下)?

我们检查输入是否为空的唯一方法是使用:placeholder-shown。但是如果我们的输入元素没有占位符会发生什么呢? 这里有个取巧的方法:传入一个空字符串" "

// html
<input placeholder=" "><!--  pass empty string -->

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

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

组合其它选择器

我们可以使用:not伪类对某些事物进行逆运算。 在这里,我们可以在输入不是空的情况下进行定位。

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

// css
input:not(:placeholder-shown) {
  border: 1px solid green;
}

实战

placeholder-shown

CSS-Pseudoklasse repräsentiert jedes Formularelement, das Platzhaltertext anzeigt.

Um es einfach auszudrücken: Was macht das Eingabefeld, wenn der Platzhalterinhalt des Eingabefelds angezeigt wird? Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSSDie Kompatibilität ist wie folgt, es gibt kein Problem auf dem mobilen Endgerät

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

Wie funktioniert placeholder-show?

:placeholder-shown Die CSS-Pseudoklasse wird wirksam, wenn das Element <input> oder <textarea></textarea> angezeigt wird Platzhaltertext. Um es einfach auszudrücken: Der Platzhalter wird nur wirksam, wenn er einen Wert hat, wie unten gezeigt:
<div class="input">
    <input class="input-fill" placeholder="邮箱">
    <label class="input-label">邮箱</label>
</div>

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS

Wenn placeholder leer ist, hat placeholder-show keine Wirkung:
.input{
   position: relative;
 }
.input-fill{
  border: 1px solid #ececec;
  outline: none;
  padding: 13px 16px 13px;
  font-size: 16px;
  line-height: 1.5;
  width: fit-content;
  border-radius: 5px;
}
.input-fill:placeholder-shown::placeholder {
  color: transparent;
}
.input-label {
  position: absolute;
  font-size: 16px;
  line-height: 1.5;
  left: 16px; top: 14px;
  color: #a2a9b6;
  padding: 0 2px;
  transform-origin: 0 0;
  pointer-events: none;
  transition: all .25s;
}
.input-fill:focus{
  border: 1px solid #2486ff;
}
.input-fill:not(:placeholder-shown) ~ .input-label,
.input-fill:focus ~ .input-label {
  transform: scale(0.75) translate(0, -32px);
  background-color: #fff;
  color: #2486ff;
}

Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜🎜

:placeholder-shown vs ::placeholder

🎜Wir können :placeholder-shown verwenden, um den Stil der Eingabe festzulegen -Element. 🎜rrreee🎜🎜Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜 🎜🎜Beachten Sie einige seltsame Probleme – wir haben Farbe: Grün festgelegt, aber es hat keine Auswirkung. Dies liegt daran, dass :placeholder-shown nur auf input selbst abzielt. Für eigentlichen Platzhaltertext muss das Pseudoelement ::placeholder verwendet werden. 🎜rrreee🎜🎜Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜 🎜🎜Mir ist aufgefallen, dass es einige andere Attribute gibt, die sich auch auf den Stil von placeholder auswirken, wenn ::placeholder-shown angewendet wird. 🎜rrreee🎜🎜🎜🎜🎜Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜🎜🎜Das weiß ich nicht Entweder Was ist los? Vielleicht liegt es daran, dass diese Attribute von placeholder geerbt werden. Wenn Sie den Grund kennen, hinterlassen Sie mir bitte eine Nachricht. 🎜

:placeholder-shown vs :empty

🎜:placeholder-shown ist ein Objekt, das speziell verwendet wird, um zu bestimmen, ob ein Element hauptsächlich einen Platzhalter anzeigt Verwenden Sie dies, um zu überprüfen, ob der Inhalt der Eingabe leer ist (vorausgesetzt, alle Eingaben haben einen Platzhalter). Sie denken hier vielleicht: Ist es in Ordnung, empty zu verwenden? Werfen wir einen Blick darauf. 🎜rrreee🎜🎜Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜 🎜🎜Es scheint, dass empty hier funktioniert, weil wir einen rosa Rand sehen, aber es funktioniert tatsächlich nicht 🎜🎜Der Grund, warum Rosa angezeigt wird, ist, dass die Pseudoklasse CSS-Gewicht hinzufügt. Ähnlich wie Klassenselektoren (z. B. .form-input) mit höherer Gewichtung als Typselektoren (z. B. input). Selektoren mit hoher Autorität überschreiben immer Stile, die von niedriger Autorität festgelegt wurden. 🎜🎜Daher können wir Folgendes sagen: Verwenden Sie nicht :empty, um zu prüfen, ob das Eingabeelement leer ist. 🎜

Wie überprüfe ich, ob der Eingabeinhalt leer ist (ohne Punktmarkierungen)?

🎜Die einzige Möglichkeit, zu überprüfen, ob die Eingabe leer ist, ist die Verwendung von :placeholder-shown. Aber was passiert, wenn unser Eingabeelement keinen Platzhalter hat? Hier ist ein Trick: Übergeben Sie einen leeren String " ". 🎜rrreee🎜🎜Detaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS🎜 🎜

Andere Selektoren kombinieren

🎜Wir können die Pseudoklasse :not verwenden, um die umgekehrte Operation von etwas auszuführen. Hier können wir positionieren, wenn die Eingabe nicht leer ist. 🎜rrreee

Praktischer Kampf

🎜Mit placeholder-shown können wir die folgenden Animationseffekte erzielen🎜🎜🎜🎜🎜🎜🎜Der spezifische Code lautet wie folgt :🎜🎜🎜Html 🎜🎜rrreee🎜🎜Css🎜🎜rrreee🎜🎜Originaladresse: https://www.samanthaming.com/tidbits/88-css-placeholder-shown/🎜

Autorin: Samantha Ming

Weitere Kenntnisse zum Thema Programmierung finden Sie unter: Einführung in die Programmierung! !

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung der durch Platzhalter angezeigten Pseudoklasse in CSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen