いくつかの入力フィールドを持つフォームがあります。これらの入力フィールドには、次のように背景としてグラデーションが割り当てられています。
input {
background: #00b7ea;
background: url();
background: -moz-linear-gradient(top, #00b7ea 0%, #009ec3 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#00b7ea), color-stop(100%,#009ec3));
background: -webkit-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: -o-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: -ms-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: linear-gradient(to bottom, #00b7ea 0%,#009ec3 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00b7ea', endColorstr='#009ec3',GradientType=0 );
}
ここで、フィールドが として検証され:valid
たら、すべて問題がないことを示す記号を追加したいと思います。通常、私は疑似要素を使用しようとします:before
が:after
、この場合はそうではありません。:before
要素内に:after
レンダリングされ、入力フィールドに他の要素を含めることは許可されていないため、それらを適切に配置する方法が見つかりませんでした。
したがって、インジケーターを背景画像として表示する必要があり、その結果、次のコードが生成されます。
input {
background: #00b7ea;
background: url(../images/ok.png), url();
background: url(../images/ok.png), -moz-linear-gradient(top, #00b7ea 0%, #009ec3 100%);
background: url(../images/ok.png), -webkit-gradient(linear, left top, left bottom, color-stop(0%,#00b7ea), color-stop(100%,#009ec3));
background: url(../images/ok.png), -webkit-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: url(../images/ok.png), -o-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: url(../images/ok.png), -ms-linear-gradient(top, #00b7ea 0%,#009ec3 100%);
background: linear-gradient(to bottom, #00b7ea 0%,#009ec3 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00b7ea', endColorstr='#009ec3',GradientType=0 );
}
さて、このソリューションは機能していますが、バックグラウンドのコードを繰り返して、ソリューションがあまり DRY にならないようにします。その問題に対する他の良い解決策を想像できますか? 私が知らないベストプラクティスはありますか?