只使用CSS3样式复选框为切换按钮

只使用CSS3样式复选框为切换按钮

文演示了如何样式普通的HTML复选框为只使用CSS3没有JavaScript切换按钮。 HTML结构是非常简单 […]

2014-05-17

文演示了如何样式普通的HTML复选框为只使用CSS3没有JavaScript切换按钮。

HTML结构是非常简单的。一个切换按钮,你将需要:输入元素(HTML复选框)和标签元素与我里面的元素。

只有一个,你必须了解HTML结构,最重要的标签元素有两个额外的属性:数据文本真和数据文本假。这些属性所使用的CSS样式在切换按钮以两种状态显示标题:检查和不检查。

一个切换按钮(复选框)的HTML代码:
<input id="checkbox1" type="checkbox" checked>
<label for="checkbox1" data-text-true="Yes" data-text-false="No"><i></i></label>
CSS styles:
 

input[type=checkbox] {
  display: none;
}

input[type=checkbox] + label {
  display: inline-block;
  background-color: #DB574D;
  color: white;
  font-family: sans-serif;
  font-size: 14px;
  font-weight: bold;
  height: 30px;
  line-height: 30px;
  position: relative;
  text-transform: uppercase;
  width: 80px;
}

input[type=checkbox] + label,
input[type=checkbox] + label i {
  -webkit-transition: all 200ms ease;
  -moz-transition: all 200ms ease;
  -o-transition: all 200ms ease;
  transition: all 200ms ease;
}

input[type=checkbox]:checked + label {
  background-color: #67B04F;
}

input[type=checkbox] + label:before,
input[type=checkbox] + label:after,
input[type=checkbox] + label i {
  width: 50%;
  display: inline-block;
  height: 100%;
  text-align: center;
}

input[type=checkbox] + label:before {
  content: attr(data-text-true);
}

input[type=checkbox] + label:after {
  content: attr(data-text-false);
}

input[type=checkbox] + label i {
  top: 10%;
  background-color: white;
  height: 80%;
  left: 5%;
  position: absolute;
  width: 45%;
}

input[type=checkbox]:checked + label i {
  left: 50%;
}