别再纠结CSS样式不统一!自定义SVG复选框不香吗?
复选框是表单应用常用的组件,复选框的默认样式一般很难覆盖。为了覆盖复选框的样式,一般使用其他标签替换复选框,本文介绍了一种采用SVG替换复选框的方法,一共有4种不同的动画风格。
效果预览
代码实现
HTML代码
<div class="wrapper">
<div class="switch_box box_1">
<input type="checkbox" class="switch_1">
</div>
<div class="switch_box box_2">
<input type="checkbox" class="switch_2">
</div>
<div class="switch_box box_3">
<div class="toggle_switch">
<input type="checkbox" class="switch_3">
<svg class="checkbox" xmlns="http://www.w3.org/2000/svg" style="isolation:isolate" viewBox="0 0 168 80">
<path class="outer-ring" d="M41.534 9h88.932c17.51 0 31.724 13.658 31.724 30.482 0 16.823-14.215 30.48-31.724 30.48H41.534c-17.51 0-31.724-13.657-31.724-30.48C9.81 22.658 24.025 9 41.534 9z" fill="none" stroke="#233043" stroke-width="3" stroke-linecap="square" stroke-miterlimit="3"/>
<path class="is_checked" d="M17 39.482c0-12.694 10.306-23 23-23s23 10.306 23 23-10.306 23-23 23-23-10.306-23-23z"/>
<path class="is_unchecked" d="M132.77 22.348c7.705 10.695 5.286 25.617-5.417 33.327-2.567 1.85-5.38 3.116-8.288 3.812 7.977 5.03 18.54 5.024 26.668-.83 10.695-7.706 13.122-22.634 5.418-33.33-5.855-8.127-15.88-11.474-25.04-9.23 2.538 1.582 4.806 3.676 6.66 6.25z"/>
</svg>
</div>
</div>
<div class="switch_box box_4">
<div class="input_wrapper">
<input type="checkbox" class="switch_4">
<svg class="is_checked" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 426.67 426.67">
<path d="M153.504 366.84c-8.657 0-17.323-3.303-23.927-9.912L9.914 237.265c-13.218-13.218-13.218-34.645 0-47.863 13.218-13.218 34.645-13.218 47.863 0l95.727 95.727 215.39-215.387c13.218-13.214 34.65-13.218 47.86 0 13.22 13.218 13.22 34.65 0 47.863L177.435 356.928c-6.61 6.605-15.27 9.91-23.932 9.91z"/>
</svg>
<svg class="is_unchecked" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 212.982 212.982">
<path d="M131.804 106.49l75.936-75.935c6.99-6.99 6.99-18.323 0-25.312-6.99-6.99-18.322-6.99-25.312 0L106.49 81.18 30.555 5.242c-6.99-6.99-18.322-6.99-25.312 0-6.99 6.99-6.99 18.323 0 25.312L81.18 106.49 5.24 182.427c-6.99 6.99-6.99 18.323 0 25.312 6.99 6.99 18.322 6.99 25.312 0L106.49 131.8l75.938 75.937c6.99 6.99 18.322 6.99 25.312 0 6.99-6.99 6.99-18.323 0-25.313l-75.936-75.936z" fill-rule="evenodd" clip-rule="evenodd"/>
</svg>
</div>
</div>
</div>
前两个利用纯CSS渲染动画,后两个利用SVG绘制了相对复杂的路径线条以及简单的符号。
CSS代码
第一个和第二个开关利用纯CSS实现,我们就已第一个效果为例:
.box_1{
background: #eee;
}
input[type="checkbox"].switch_1{
font-size: 30px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
width: 3.5em;
height: 1.5em;
background: #ddd;
border-radius: 3em;
position: relative;
cursor: pointer;
outline: none;
-webkit-transition: all .2s ease-in-out;
transition: all .2s ease-in-out;
}
input[type="checkbox"].switch_1:checked{
background: #0ebeff;
}
input[type="checkbox"].switch_1:after{
position: absolute;
content: "";
width: 1.5em;
height: 1.5em;
border-radius: 50%;
background: #fff;
-webkit-box-shadow: 0 0 .25em rgba(0,0,0,.3);
box-shadow: 0 0 .25em rgba(0,0,0,.3);
-webkit-transform: scale(.7);
transform: scale(.7);
left: 0;
-webkit-transition: all .2s ease-in-out;
transition: all .2s ease-in-out;
}
input[type="checkbox"].switch_1:checked:after{
left: calc(100% - 1.5em);
}
第三个效果虽然已经用SVG画了一轮弯月,但CSS的样式渲染也是必不可少的:
.box_3{
background: #19232b;
}
.toggle_switch{
width: 100px;
height: 45px;
position: relative;
}
input[type="checkbox"].switch_3{
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
width: 100%;
height: 100%;
cursor: pointer;
outline: 0;
z-index: 1;
}
svg.checkbox .outer-ring{
stroke-dasharray: 375;
stroke-dashoffset: 375;
-webkit-animation: resetRing .35s ease-in-out forwards;
animation: resetRing .35s ease-in-out forwards;
}
input[type="checkbox"].switch_3:checked + svg.checkbox .outer-ring{
-webkit-animation: animateRing .35s ease-in-out forwards;
animation: animateRing .35s ease-in-out forwards;
}
input[type="checkbox"].switch_3:checked + svg.checkbox .is_checked{
opacity: 1;
-webkit-transform: translateX(0) rotate(0deg);
transform: translateX(0) rotate(0deg);
}
input[type="checkbox"].switch_3:checked + svg.checkbox .is_unchecked{
opacity: 0;
-webkit-transform: translateX(-200%) rotate(180deg);
transform: translateX(-200%) rotate(180deg);
}
svg.checkbox{
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
width: 100%;
height: 100%;
}
svg.checkbox .is_checked{
opacity: 0;
fill: yellow;
-webkit-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-webkit-transform: translateX(200%) rotate(45deg);
transform: translateX(200%) rotate(45deg);
-webkit-transition: all .35s;
transition: all .35s;
}
svg.checkbox .is_unchecked{
opacity: 1;
fill: #fff;
-webkit-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-webkit-transform: translateX(0) rotate(0deg);
transform: translateX(0) rotate(0deg);
-webkit-transition: all .35s;
transition: all .35s;
}
@-webkit-keyframes animateRing{
to{
stroke-dashoffset: 0;
stroke: #b0aa28;
}
}
@keyframes animateRing{
to{
stroke-dashoffset: 0;
stroke: #b0aa28;
}
}
@-webkit-keyframes resetRing{
to{
stroke-dashoffset: 0;
stroke: #233043;
}
}
@keyframes resetRing{
to{
stroke-dashoffset: 0;
stroke: #233043;
}
}
源码下载
完整的代码我已经整理出了一个源码包,供大家下载学习。
关注我的公众号“前端技术官”,回复关键字:1001,即可获取源码下载链接。
代码仅供参考和学习,请不要用于商业用途。
本文完,感谢大家阅读。
转载自:https://juejin.cn/post/7087075107784359966