gpt4 book ai didi

html - 多重背景 & :valid - shortest solution/DRY solution?

转载 作者:行者123 更新时间:2023-11-28 03:35:27 26 4
gpt4 key购买 nike

我有一个带有一些输入字段的表单。这些输入字段具有指定的背景渐变,如下所示:

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 );
}

现在,虽然这个解决方案有效,但我重复了后台代码,这样解决方案就不是很干了。你能想出任何其他好的解决方案来解决这个问题吗?有什么我不知道的最佳做法吗?

最佳答案

您可以将附加图像 (on.png) 设置为边框图像而非背景图像

input:valid {
border-image: url(../images/ok.png);
}

但不确定是否支持旧版浏览器

关于html - 多重背景 & :valid - shortest solution/DRY solution?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14677022/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com