⾃定义radio的样式,更改选中样式
思路:
1. 可以为<label>元素添加⽣成性内容(伪元素),并基于单选按钮的状态来为其设置样式;
2. 然后把真正的单选按钮隐藏起来;
3. 最后把⽣成内容美化⼀下。
解决⽅法:
1. ⼀段简单的结构代码:
<div class="female">
<input type="radio" id="female" name="sex" />
<label for="female">⼥</label>
</div>
<div class="male">
<input type="radio" id="male" name="sex" />
<label for="male">男</label>
</div>
2. ⽣成⼀个伪元素,作为美化版的单选按钮,先给伪元素添加⼀些样式:
input[type="radio"] + label::before {
content: "\a0"; /*不换⾏空格*/
display: inline-block;
vertical-align: middle;
font-size: 18px;
width: 1em;
height: 1em;
margin-right: .4em;
border-radius: 50%;
border: 1px solid #01cd78;
text-indent: .15em;
line-height: 1;
}
注:可以通过margin-top来调节位置
现在的样⼦:
原来的单选按钮仍然可见,但是我们先给单选按钮的勾选状态添加样式:
3. 给单选按钮的勾选状态添加不同的样式:
input[type="radio"]:checked + label::before {
background-color: #01cd78;
background-clip: content-box;
padding: .2em;
}
现在的样⼦:
4. 现在把原来的单选按钮隐藏:
input[type="radio"] {
position: absolute;
clip: rect(0, 0, 0, 0);
htmlradio的text出不来
}
现在的样⼦:
隐藏原来的单选按钮时,如果使⽤ display: none; 的话,那样会把它从键盘 tab 键切换焦点的队列中完全删除。于是可采⽤剪切的⽅式,让剪切后的尺⼨为零,这样就隐藏了原来的单选按钮。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。