css实现switch开关

最终实现效果

使用场景:当使用的UI框架没提供类似的switch开关组件或者组件不能完全满足UI设计的显示需求,需要进行样式自定义,或者作为组件形式引入

<h2>开关切换</h2>

<!--开-->
<label class="switch" >
  <input type="checkbox" >
  <div class="slider round checked">
    <span  class="slider-text on" >开</span>
  </div>
 </label>
<!--关-->
<label class="switch" >
  <input type="checkbox" >
  <div class="slider round">
    <span class="slider-text">关</span>
  </div>
 </label>

说明:以下html+css实现了带有“开”、“关”文字标识的基本switch开关样式,  通过class="round"控制圆角的显示,通过class="checked" 及class="on" 控制选中样式显示

css




.switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 22px;
}

.switch input {
  display:none;
}
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider.checked {
  background-color: #2196F3;
}

.slider.checked:before {
  -webkit-transform: translateX(22px);
  -ms-transform: translateX(22px);
  transform: translateX(22px);
}
.slider.round {
  border-radius: 34px;
}

.slider.round:before {
  border-radius: 50%;
}
.slider-text{
  color: #fff;
  position: absolute;
  left: 24px;
  margin: 0 auto;
  font-size:12px;
  line-height: 22px
}
.on.slider-text{
   left: 8px;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值