浮動プレースホルダーを持つ2つの入力フィールドがあります。フォーカスすると、プレースホルダが上に移動し、ユーザーが入力するためのスペースが作成されます。しかし、ユーザーが入力を開始するとすぐに消えます。テキストボックスに何かを入力した後、プレースホルダを同じ場所に置いておきたいです。これはCSSだけを使って可能ですか?あなたはlabel
を使用する必要がありますコメントし入力後にプレースホルダーを保持する
input {
width: 100%;
display: block;
border: none;
padding: 20px 0 10px 0;
border-bottom: solid 1px #343a40;
-webkit-transition: all 0.3s cubic-bezier(0.64, 0.09, 0.08, 1);
transition: all 0.3s cubic-bezier(0.64, 0.09, 0.08, 1);
background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 99%, #007bff 1%);
background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 99%, #007bff 1%);
background-position: -1000px 0;
background-size: auto 100%;
background-repeat: no-repeat;
color: #000;
}
input:focus,
input:valid {
box-shadow: none;
outline: none;
background-position: 0 0;
}
input::-webkit-input-placeholder {
font-family: 'roboto', sans-serif;
-webkit-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}
input:focus::-webkit-input-placeholder,
input:valid::-webkit-input-placeholder {
color: #007bff;
font-size: 12px;
-webkit-transform: translateY(-20px);
transform: translateY(-20px);
visibility: visible !important;
}
<input placeholder="Username" type="text" required>
<input placeholder="Password" type="password" required>
http://caniuse.com/#search=%3Avalidは、プレースホルダとスタイルのラベル –
そうでもないのではなく、ラベルを使用してくださいinplementedです。プレースホルダーの代わりにラベルを使用した場合、[プレースホルダーはとにかく有害であるとみなされます](https://www.nngroup.com/articles/form-design-placeholders/)。しかし、公正であるためには(フローティングラベルのパターンもあります)(https://medium.com/simple-human/floating-labels-are-a-bad-idea-82edb64220f6)。だから、もしアクセシビリティがデザイナーの虚栄心だけでなく、あなたの焦点であるならば、おそらくどちらかを使うべきではありません。 – CBroe
それは本当に意味がある..ありがとう@CBroe – Venky