<label for="man" class="radio">
<span class="radio-bg"></span>
<input type="radio" name="sex" id="man" value="男" checked="checked" />男
<span class="radio-on"></span>
</label>
这个方法中最重要的是选中效果的类名:.radio input:checked + span.radio-on
+是CSS2的伪类,其意义为:p+p 选择紧接在 <p>元素之后的所有 <p>元素。
也就是找到选中的(:checked)的input,其之后的类名为radio-on的span元素做选中圆圈效果。
网上有很多美化方法是把label做成了圆圈,但是这样的话,单选的文字就必须要要放到label的外面,这导致了点击文字的时候,不能切换单选效果。
所以我在label里加了一个类名为radio-bg的span来专门做后面大的圆圈,再用一个类名为radio-on的span来做选中的前面小的圆圈。
这样就保留了点击label里的文字,也可以切换单选的效果。
以上就是如何使用纯CSS3美化单选按钮radio的示例代码分享的方法
radio单选按钮默认样式改变,radio默认样式确实有点丑,而且不能适合所有的UI设计稿,现在UI稿的花样是越来越多了,所有使用css自定义radio单选按钮样式还是很重要的.
在不使用js的情况下就改变了radio的按钮样式了,既然是自定义样式,就可以随心情自己修改了,我这里实现的效果是这样的
要是需要兼容的raio样式。只能用div和图片去模拟。不能使用input。这样对于样式就很好操作了。但是会出现一个问题就是要是有提交表单的信息的时候没有办法提交。所以需要设计到隐藏域的知识点。就是一个input 设置为hidden来传递数据。这样的话就可以做到兼容的有样式的radio