纯CSS实现可交互开关

效果

HTML

html 复制代码
<label class="switch">
    <input type="checkbox" class="switch__input" />
    <span class="circle"></span>
</label>


<script type="text/javascript">
    document.querySelector('.switch').onclick = function () {
        console.log(document.querySelector('.switch__input').checked)
    }
</script>

实现思路

  • 首先要根据input的值来改变样式
  • input要隐藏,同时需要可以点击

初始化样式

先定义变量

css 复制代码
 :root {
    --border-c: #409eff;
    --checked-c: #409eff;
    --size: 40px;
}

设置label样式,这里border-radius不是百分比,而是近乎无限大的值,这样能仅让两边变圆

css 复制代码
.switch {
    position: relative;
    display: block;
    height: var(--size);
    width: calc(var(--size) * 2);
    border-radius: 9999px;
    border: 1px solid var(--border-c);
}

设置input样式,只需要透明,加上铺满即可

css 复制代码
.switch__input {
    position: absolute;
    inset: 0;
    opacity: 0;
}

.circle {
    position: absolute;
    top: 0;
    left: 0;
    height: var(--size);
    width: var(--size);
    border-radius: 50%;
    background-color: #fff;
    border: 1px solid var(--border-c);
    box-sizing: border-box;
}

现在效果如下

接下来点击时,会改变input的值,所以根据这个值,我们来设置样式

check时,把兄弟元素向右移动即可,再给圆球加个动画

css 复制代码
.switch__input:checked + .circle {
    transform: translateX(100%);
}

.circle {
    transition: transform .3s;
}

效果如下

接下来是重头戏了,那就是背景颜色怎么根据值来改变呢

传统方式是用js控制,不过都什么年代了,还在写传统js

css 复制代码
 .switch:has(.switch__input:checked) {
    background-color: var(--checked-c);
}

这样就能实现了,这是什么意思呢??

:has选择器,即.switch里的元素,被checked就会触发

这时,当按钮被点击背景颜色就会变

最后加个动画就好了

css 复制代码
.switch {
    position: relative;
    display: block;
    height: var(--size);
    width: calc(var(--size) * 2);
    border-radius: 9999px;
    border: 1px solid var(--border-c);
    transition: background-color .6s .1s;
}

总共0.6s的动画,是按钮移动时长了两倍,并且延迟0.1s触发,这样就很丝滑

源码 gitee.com/cjl2385/dig...

相关推荐
QT 小鲜肉8 小时前
【Linux命令大全】001.文件管理之mtoolstest命令(实操篇)
linux·运维·前端·笔记·microsoft
holeer8 小时前
React UI组件封装实战——以经典项目「个人博客」与「仿手机QQ」为例
前端·javascript·react.js·ui·前端框架·软件工程
chilavert3188 小时前
技术演进中的开发沉思-277 AJax :Calendar
前端·javascript·microsoft·ajax
debug 小菜鸟8 小时前
搭建web 环境的那些事
前端
鹏多多8 小时前
Flutter下拉刷新上拉加载侧拉刷新插件:easy_refresh全面使用指南
android·前端·ios
Mike_jia8 小时前
OpenDeRisk:AI 原生风险智能系统 ——7*24H 应用系统AI数字运维助手(AI-SRE)
前端
朱穆朗8 小时前
electron升级到33.0.x版本后,devtools字体的修改方法
前端·javascript·electron
IT_陈寒9 小时前
Java 21新特性实战:5个必学的性能优化技巧让你的应用提速40%
前端·人工智能·后端
HarrySunCn9 小时前
大夏龙雀DX-CT511N-B实战之路-第1步
前端·单片机·物联网·iot
未来之窗软件服务9 小时前
幽冥大陆(七十七)C# 调用 中文huayan-medium.onnx —东方仙盟练气期
前端·ui·c#·仙盟创梦ide·东方仙盟