84669 Lernen von Personen
152542 Lernen von Personen
20005 Lernen von Personen
5487 Lernen von Personen
7821 Lernen von Personen
359900 Lernen von Personen
3350 Lernen von Personen
180660 Lernen von Personen
48569 Lernen von Personen
18603 Lernen von Personen
40936 Lernen von Personen
1549 Lernen von Personen
1183 Lernen von Personen
32909 Lernen von Personen
Ich versuche, ein Kontrollkästchen wie folgt zu gestalten:
Aber der Stil wurde nicht angewendet. Das Kontrollkästchen zeigt weiterhin seinen Standardstil an. Wie kann man ihm einen bestimmten Stil verleihen?
通过使用:after和:before伪类附带的新功能,您可以实现非常酷的自定义复选框效果。这样做的优点是:您不需要向 DOM 添加任何其他内容,只需添加标准复选框即可。
:after
:before
请注意,这仅适用于兼容的浏览器。我相信这与某些浏览器不允许您在输入元素上设置:after和:before有关。不幸的是,这意味着目前仅支持 WebKit 浏览器。 Firefox + Internet Explorer 仍然允许复选框发挥作用,只是没有样式,这有望在未来发生变化(代码不使用供应商前缀)。
这只是一个 WebKit 浏览器解决方案(Chrome、Safari、移动浏览器)
查看示例 Fiddle
$(function() { $('input').change(function() { $('div').html(Math.random()); }); });
/* Main Classes */ .myinput[type="checkbox"]:before { position: relative; display: block; width: 11px; height: 11px; border: 1px solid #808080; content: ""; background: #FFF; } .myinput[type="checkbox"]:after { position: relative; display: block; left: 2px; top: -11px; width: 7px; height: 7px; border-width: 1px; border-style: solid; border-color: #B3B3B3 #dcddde #dcddde #B3B3B3; content: ""; background-image: linear-gradient(135deg, #B1B6BE 0%, #FFF 100%); background-repeat: no-repeat; background-position: center; } .myinput[type="checkbox"]:checked:after { background-image: url(''), linear-gradient(135deg, #B1B6BE 0%, #FFF 100%); } .myinput[type="checkbox"]:disabled:after { -webkit-filter: opacity(0.4); } .myinput[type="checkbox"]:not(:disabled):checked:hover:after { background-image: url(''), linear-gradient(135deg, #8BB0C2 0%, #FFF 100%); } .myinput[type="checkbox"]:not(:disabled):hover:after { background-image: linear-gradient(135deg, #8BB0C2 0%, #FFF 100%); border-color: #85A9BB #92C2DA #92C2DA #85A9BB; } .myinput[type="checkbox"]:not(:disabled):hover:before { border-color: #3D7591; } /* Large checkboxes */ .myinput.large { height: 22px; width: 22px; } .myinput.large[type="checkbox"]:before { width: 20px; height: 20px; } .myinput.large[type="checkbox"]:after { top: -20px; width: 16px; height: 16px; } /* Custom checkbox */ .myinput.large.custom[type="checkbox"]:checked:after { background-image: url(''), linear-gradient(135deg, #B1B6BE 0%, #FFF 100%); } .myinput.large.custom[type="checkbox"]:not(:disabled):checked:hover:after { background-image: url(''), linear-gradient(135deg, #8BB0C2 0%, #FFF 100%); }
额外的 Webkit 风格翻转小提琴
$(function() { var f = function() { $(this).next().text($(this).is(':checked') ? ':checked' : ':not(:checked)'); }; $('input').change(f).trigger('change'); });
body { font-family: arial; } .flipswitch { position: relative; background: white; width: 120px; height: 40px; -webkit-appearance: initial; border-radius: 3px; -webkit-tap-highlight-color: rgba(0, 0, 0, 0); outline: none; font-size: 14px; font-family: Trebuchet, Arial, sans-serif; font-weight: bold; cursor: pointer; border: 1px solid #ddd; } .flipswitch:after { position: absolute; top: 5%; display: block; line-height: 32px; width: 45%; height: 90%; background: #fff; box-sizing: border-box; text-align: center; transition: all 0.3s ease-in 0s; color: black; border: #888 1px solid; border-radius: 3px; } .flipswitch:after { left: 2%; content: "OFF"; } .flipswitch:checked:after { left: 53%; content: "ON"; }
Webkit friendly mobile-style checkbox/flipswitch
更新:
下面的答案参考了 CSS 3 广泛使用之前的情况。在现代浏览器(包括 Internet Explorer 9 及更高版本)中,使用您喜欢的样式创建复选框替换更加简单,无需使用 JavaScript。
以下是一些有用的链接:
值得注意的是,根本问题没有改变。您仍然无法将样式(边框等)直接应用于复选框元素并使这些样式影响 HTML 复选框的显示。然而,发生的变化是,现在可以隐藏实际的复选框并将其替换为您自己的样式元素,只使用 CSS 即可。特别是,由于 CSS 现在具有广泛支持的:checked选择器,因此您可以使替换正确反映框的选中状态。
:checked
旧答案
这是一篇关于样式化复选框的有用文章。基本上,该作者发现它在不同浏览器之间存在巨大差异,并且无论您如何设计它,许多浏览器总是显示默认复选框。所以确实没有一个简单的方法。
不难想象一种解决方法,您可以使用 JavaScript 在复选框上覆盖图像,然后单击该图像导致检查真正的复选框。没有 JavaScript 的用户将看到默认复选框。
编辑添加:这里是一个很好的脚本,可以为您完成此操作;它隐藏了真正的复选框元素,用样式化的范围替换它,并重定向点击事件。
通过使用
:after
和:before
伪类附带的新功能,您可以实现非常酷的自定义复选框效果。这样做的优点是:您不需要向 DOM 添加任何其他内容,只需添加标准复选框即可。请注意,这仅适用于兼容的浏览器。我相信这与某些浏览器不允许您在输入元素上设置
:after
和:before
有关。不幸的是,这意味着目前仅支持 WebKit 浏览器。 Firefox + Internet Explorer 仍然允许复选框发挥作用,只是没有样式,这有望在未来发生变化(代码不使用供应商前缀)。这只是一个 WebKit 浏览器解决方案(Chrome、Safari、移动浏览器)
查看示例 Fiddle
额外的 Webkit 风格翻转小提琴
更新:
下面的答案参考了 CSS 3 广泛使用之前的情况。在现代浏览器(包括 Internet Explorer 9 及更高版本)中,使用您喜欢的样式创建复选框替换更加简单,无需使用 JavaScript。
以下是一些有用的链接:
值得注意的是,根本问题没有改变。您仍然无法将样式(边框等)直接应用于复选框元素并使这些样式影响 HTML 复选框的显示。然而,发生的变化是,现在可以隐藏实际的复选框并将其替换为您自己的样式元素,只使用 CSS 即可。特别是,由于 CSS 现在具有广泛支持的
:checked
选择器,因此您可以使替换正确反映框的选中状态。旧答案
这是一篇关于样式化复选框的有用文章。基本上,该作者发现它在不同浏览器之间存在巨大差异,并且无论您如何设计它,许多浏览器总是显示默认复选框。所以确实没有一个简单的方法。
不难想象一种解决方法,您可以使用 JavaScript 在复选框上覆盖图像,然后单击该图像导致检查真正的复选框。没有 JavaScript 的用户将看到默认复选框。
编辑添加:这里是一个很好的脚本,可以为您完成此操作;它隐藏了真正的复选框元素,用样式化的范围替换它,并重定向点击事件。