欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

label input实现按钮开关切换效果

程序员文章站 2022-03-26 18:31:28
...

label input实现按钮开关切换效果

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .ipt {
            display: none;
        }
        .box {
            width: 74px;
            height: 30px;
            line-height: 30px;
            overflow: hidden;
            border: 1px solid #eee;
            border-radius: 4px;
            position: relative;
            cursor: pointer;
        }
       label {display:inline-block;}
        .ipt:checked   .box .switch-btn {
            left: 0;
        }
        .switch-btn {
            position: absolute;
            left: -37px;
            top: 0;
            width: 111px;
            height: 30px;
            transition: all 0.5s;
        }
        .switch-btn span{
            width: 37px;
            height: 30px;
            display: block;
            text-align: center;            
            float: left;
            font-size: 14px;
        }
        .on {
            background: #52B13C;
            color: white;
        }
        .white {
            background: white;
        }
        .off {
            background: #EEEEEE;
        }
    </style>
</head>
<body>
    <p>主要使用label input来实现改变left的值,下面是核心代码,意思就是<code>选中的input的兄弟节点.box下的.switch-btn元素的left会变成0px(原来是-37px);</code></p>
    <pre>
        .ipt:checked   .box .switch-btn {
            left: 0;
        }
    </pre>
    <p>当然要配合transition来实现</p>
    <p>下面是效果</p>
    <div class="wrap">
        <label>
            <input class="ipt" type="checkbox" name="" value="">
            <div class="box">
                <div class="switch-btn">
                    <span class="on">ON</span>
                    <span class="white"></span>
                    <span class="off">OFF</span>
                </div>
            </div>
        </label>
    </div>
    <p>全部css代码</p>
    <pre>
            .ipt {
                display: none;
            }
            .box {
                width: 74px;
                height: 30px;
                line-height: 30px;
                overflow: hidden;
                border: 1px solid #eee;
                border-radius: 4px;
                position: relative;
                cursor: pointer;
            }
            .ipt:checked   .box .switch-btn {
                left: 0;
            }
            .switch-btn {
                position: absolute;
                left: -37px;
                top: 0;
                width: 111px;
                height: 30px;
                transition: all 0.5s;
            }
            .switch-btn span{
                width: 37px;
                height: 30px;
                display: block;
                text-align: center;            
                float: left;
                font-size: 14px;
            }
            .on {
                background: #52B13C;
                color: white;
            }
            .white {
                background: white;
            }
            .off {
                background: #EEEEEE;
            }
    </pre>
</body>
</html>

 

相关标签: label