本文为博主原创,转载请注明出处。  

  Switch开关:

  

  

  根据需求可知,Switch开关只有两种选择,true或false。所以我们想到HTML的checkbox控件,用它来做。  

<input id="switch" type="checkbox" class="switch" />

  但是在浏览器中,checkbox是有固定形状的(对勾),所以我们并不能直接修改checkbox的样式。

  那我们该修改一个什么东西的样式变成开关呢?所以我们联想到 label 标签,为什么呢?因为label标签的for属性可以绑定表单控件,点击label标签,就相当于你点击了绑定的那个控件。

<label for="switch">test</label>

  

  废话不多说,直接上完整代码:  

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<link rel="stylesheet" href="css/test.css" />
</head>
<body>
<div class="switch-container">
<input id="switch" type="checkbox" class="switch" />
<label for="switch" onclick="test()"></label>
</div> <script>
var test = function(){
console.log(!document.getElementById('switch').checked ? "选中" : "未选中");
}
</script>
</body>
</html>
/*开关的大小*/
.switch-container {
height: 15px;
width: 30px;
} /*设置checkbox不显示*/
.switch {
display: none;
} /*设置label标签为椭圆状*/
label {
display: block;
background-color: #EEEEEE;
height: 100%;
width: 100%;
cursor: pointer;
border-radius: 25px;
} /*在label标签内容之前添加如下样式,形成一个未选中状态*/
label:before {
content: '';
display: block;
border-radius: 25px;
height: 100%;
width: 15px;
background-color: white;
opacity:;
box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.08);
-webkit-transition: all 0.2s ease;
} /*在label标签内容之后添加如下样式,形成一个选中状态*/
label:after {
position: relative;
top: -15px;
left: 15px;
content: '';
display: block;
border-radius: 25px;
height: 100%;
width: 15px;
background-color: white;
opacity:;
box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.08);
-webkit-transition: all 0.2s ease;
} /* ~ 兄弟选择符。
p~ul :位于 p 元素之后的所有 ul 元素
*/ /*选中后,选中样式显示*/
#switch:checked~label:after {
opacity:;
} /*选中后,未选中样式消失*/
#switch:checked~label:before {
opacity:;
} /*选中后label的背景色改变*/
#switch:checked~label {
background-color: green;
}

  如果你用了sass,可以设置变量,来改变你的开关的大小。

$switchHeight: 30px;
$switchWidth: 60px; /*改变大小只需要改变这个两个的值,后面会用到这两个值*/
.switch-container {
height: $switchHeight;
width: $switchWidth;
margin-bottom: 5px; .switch {
display: none;
} label {
display: block;
background-color: #EEEEEE;
height: 100%;
width: 100%;
cursor: pointer;
border-radius: 25px;
} label:before {
content: '';
display: block;
border-radius: 25px;
height: 100%;
width: $switchHeight;
background-color: white;
opacity:;
box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.08);
-ms-transition: all 0.2s ease; /* IE 9 */
-moz-transition: all 0.2s ease; /* Firefox */
-webkit-transition: all 0.2s ease;/* Safari and Chrome */
-o-transition: all 0.2s ease; /* Opera */
} label:after {
position: relative;
top: -$switchHeight;
left: $switchHeight;
content: '';
display: block;
border-radius: 25px;
height: 100%;
width: $switchHeight;
background-color: white;
opacity:;
box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.08);
-ms-transition: all 0.2s ease; /* IE 9 */
-moz-transition: all 0.2s ease; /* Firefox */
-webkit-transition: all 0.2s ease;/* Safari and Chrome */
-o-transition: all 0.2s ease; /* Opera */
} #switch:checked~label:after {
opacity:;
} #switch:checked~label:before {
opacity:;
} #switch:checked~label {
background-color: green;
}
}

CSS做一个Switch开关的更多相关文章

  1. 【CSS】如何用css做一个爱心

    摘要:HTML的标签都比较简单,入门非常的迅速,但是CSS是一个需要我们深度挖掘的东西,里面的很多样式属性掌握几个常用的便可以实现很好看的效果,下面我便教大家如何用CSS做一个爱心. 前期预备知识: ...

  2. 如何用css做一个爱心

    摘要:HTML的标签都比较简单,入门非常的迅速,但是CSS是一个需要我们深度挖掘的东西,里面的很多样式属性掌握几个常用的便可以实现很好看的效果,下面我便教大家如何用CSS做一个爱心. 前期预备知识: ...

  3. 简单说 用CSS做一个魔方旋转的效果

    说明 魔方大家应该是不会陌生的,这次我们来一起用CSS实现一个魔方旋转的特效,先来看看效果图! 解释 我们要做这样的效果,重点在于怎么把6张图片,摆放成魔方的样子,而把它们摆放成魔方的样子,重点在于用 ...

  4. js/html/css做一个简单的图片自动(auto)轮播效果//带注释

    FF(firefox)/chrom/ie稳定暂无bug...注意:请自己建立一个images文件,放入几张900*238的图片(注意图片格式和名字与程序中一致). 1. [图片] 1.JPG 2. [ ...

  5. 前端每日实战:145# 视频演示如何用纯 CSS 创作一个电源开关控件

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/PdMyJd 可交互视频 此视频是可 ...

  6. 如何用css做一个细虚线边框表格

    <style type="text/css"> <!-- .dashed_tbl { border-top: 1px dashed #333333; border ...

  7. css代码实现switch开关滑动

    效果预览: 代码如下: <style> #toggle-button{ display: none; } .button-label{ position: relative; displa ...

  8. 项目实践2:(问卷)用html和css做一个网页

    好家伙,又来写项目了 1.以下是考题,姑且把他理解为甲方吧. 2.以下是附带的题目素材 开干.

  9. 自定义常用input表单元素三:纯css实现自定义Switch开关按钮

    自定义常用input表单元素的第三篇,自定义一个Switch开关,表面上看是和input没关系,其实这里采用的是checkbox的checked值的切换.同样,采用css伪类和"+" ...

随机推荐

  1. 深入理解Java线程池:ThreadPoolExecutor

    线程池介绍 在web开发中,服务器需要接受并处理请求,所以会为一个请求来分配一个线程来进行处理.如果每次请求都新创建一个线程的话实现起来非常简便,但是存在一个问题: 如果并发的请求数量非常多,但每个线 ...

  2. Hexo的搭建

    Hexo的安装与初始化 1.确保电脑已经安装Node.js,Git 打开GUI Bash,输入以下代码安装Hexo: npm install -g hexo-cli 2.运行以下命令在目标文件夹初始化 ...

  3. EF DataFirst修改数据类型

    在做软件的时候我们可能会遇到这样的问题,就是在使用EF的时候,有时候精度不一样, 我们用整数来计算肯定是比浮点数来得快的,但我在MySQL里面存储的数据类型是decimal的,我生成EF后, 里面的数 ...

  4. git命令(持续更新)

    将远程仓库中的代码下载到本地仓库:git clone git仓库地址 将本地仓库中修改的文件提交到远程仓库:git push -u origin master 将当前目录添加到本地仓库,.表示当前目录 ...

  5. MVC 、JDBC、SQL、DBMS、RDBMS、DDL、DML、DCL

    MVC: 全称:Model View Controller: 解释:模型(model)-视图(view)-控制器(controller) Model(模型)表示应用程序核心(比如数据库记录列表). V ...

  6. 设计模式(13)--Chain of Responsibility(责任链模式)--行为型

    作者QQ:1095737364    QQ群:123300273     欢迎加入! 1.模式定义: 责任链模式是一种对象的行为模式.在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一 ...

  7. oop(Object Oriented Programming)

    嗯,昨天忙了一天没来及发,过年啊,打扫啊,什么搽窗户啊,拖地啊,整理柜子啊,什么乱七八糟的都有,就是一个字,忙. 好了,废话也不多说,把自己学到的放上来吧.嗯,说什么好呢,就说原型链啊 原型对象 每个 ...

  8. 大数据时代,银行BI应用的方案探讨

    大数据被誉为21世纪发展创造的新动力,BI(商业智能)成为当下最热门的数据应用方案.据资料显示:当前中国大数据IT投资最高的为五个行业中,互联网最高.其次是电信.金融.政府和医疗.而在金融行业中,银行 ...

  9. Cobalt Strike 学习

    前言 本文以一个模拟的域环境为例对 Cobalt Strike 的使用实践一波. 环境拓扑图如下: 攻击者(kali) 位于 192.168.245.0/24 网段,域环境位于 192.168.31. ...

  10. 【Java入门提高篇】Day20 Java容器类详解(三)List接口

    今天要说的是Collection族长下的三名大将之一,List,Set,Queue中的List,它们都继承自Collection接口,所以Collection接口的所有操作,它们自然也是有的. Lis ...