使用CSS3编写类似iOS中的复选框及带开关的按钮


Posted in HTML / CSS onApril 11, 2016

checkbox多选

最近写了一个适合移动端的checkbox,如图:
使用CSS3编写类似iOS中的复选框及带开关的按钮

ps:中间的勾勾是iconfont,iOS风格的。

具体的HTML:

XML/HTML Code复制内容到剪贴板
  1. <div class="mui-checkbox-con">  
  2.     <label>  
  3.         <input class="mui-checkbox" type="checkbox">默认未选中</label>  
  4. </div>  
  5. <div class="mui-checkbox-con">  
  6.     <label>  
  7.         <input class="mui-checkbox" type="checkbox" checked>默认选中</label>  
  8. </div>  
  9. <div class="mui-checkbox-con">  
  10.     <label>  
  11.         <input class="mui-checkbox checkbox-orange" type="checkbox" checked>橘黄色 checkbox-orange</label>  
  12. </div>  
  13. <div class="mui-checkbox-con">  
  14.     <label>  
  15.         <input class="mui-checkbox checkbox-green" type="checkbox" checked>绿色 checkbox-green</label>  
  16. </div>  
  17. <div class="mui-checkbox-con">  
  18.     <label>  
  19.         <input class="mui-checkbox" type="checkbox" disabled>禁用</label>  
  20. </div>  

CSS代码(SCSS导出的,排版有些奇怪):

CSS Code复制内容到剪贴板
  1. .mui-checkbox {   
  2.   -webkit-appearance: none;   
  3.   positionrelative;   
  4.   width25px;   
  5.   height25px;   
  6.   margin-right10px;   
  7.   background-color#FFFFFF;   
  8.   bordersolid 1px #d9d9d9;   
  9.   border-top-left-radius: 20px;   
  10.   border-top-rightright-radius: 20px;   
  11.   border-bottom-left-radius: 20px;   
  12.   border-bottom-rightright-radius: 20px;   
  13.   background-clippadding-box;   
  14.   displayinline-block; }   
  15.   .mui-checkbox:focus {   
  16.     outline: 0 none;   
  17.     outline-offset: -2px; }   
  18.   .mui-checkbox:checked {   
  19.     background-color#18b4ed;   
  20.     bordersolid 1px #FFFFFF; }   
  21.     .mui-checkbox:checked:before {   
  22.       displayinline-block;   
  23.       margin-top1px;   
  24.       margin-left2px;   
  25.       font-family: iconfont;   
  26.       content"\e667";   
  27.       color#FFFFFF;   
  28.       font-size18px; }   
  29.   .mui-checkbox:disabled {   
  30.     background-color#d9d9d9;   
  31.     bordersolid 1px #d9d9d9; }   
  32.     .mui-checkbox:disabled:before {   
  33.       displayinline-block;   
  34.       margin-top1px;   
  35.       margin-left2px;   
  36.       font-family: iconfont;   
  37.       content"\e667";   
  38.       color#FFFFFF;   
  39.       font-size18px; }   
  40.   .mui-checkbox.checkbox-green:checked {   
  41.     background-color#5cb85c; }   
  42.   .mui-checkbox.checkbox-orange:checked {   
  43.     background-color#f0ad4e; }   
  44.   .mui-checkbox.checkbox-s {   
  45.     width19px;   
  46.     height19px; }   
  47.     .mui-checkbox.checkbox-s:before {   
  48.       displayinline-block;   
  49.       margin-top1px;   
  50.       margin-left2px;   
  51.       font-family: iconfont;   
  52.       content"\e667";   
  53.       color#FFFFFF;   
  54.       font-size13px; }   
  55.     
  56. .mui-checkbox-anim {   
  57.   -webkit-transition: background-color ease 0.2s;   
  58.           transition: background-color ease 0.2s; }  

SCSS代码:

CSS Code复制内容到剪贴板
  1. @mixin checkedCon($fs:18px) {   
  2.   &:before {   
  3.     displayinline-block;   
  4.     margin-top1px;   
  5.     margin-left2px;   
  6.     font-family: iconfont;   
  7.     content"\e667";   
  8.     color#FFFFFF;   
  9.     font-size: $fs;   
  10.   }   
  11. }   
  12. $duration: .4s;   
  13. .mui-checkbox {   
  14.   -webkit-appearance: none;   
  15.   positionrelative;   
  16.   width25px;   
  17.   height25px;   
  18.   margin-right10px;   
  19.   background-color#FFFFFF;   
  20.   bordersolid 1px #d9d9d9;   
  21.   border-top-left-radius: 20px;   
  22.   border-top-rightright-radius: 20px;   
  23.   border-bottom-left-radius: 20px;   
  24.   border-bottom-rightright-radius: 20px;   
  25.   background-clippadding-box;   
  26.   displayinline-block;   
  27.   &:focus {   
  28.     outline: 0 none;   
  29.     outline-offset: -2px  
  30.   }   
  31.   &:checked {   
  32.     background-color#18b4ed;   
  33.     bordersolid 1px #FFFFFF;   
  34.     @include checkedCon();   
  35.   }   
  36.   &:disabled {   
  37.     background-color#d9d9d9;   
  38.     bordersolid 1px #d9d9d9;   
  39.     @include checkedCon();   
  40.   }   
  41.   &.checkbox-green:checked {   
  42.     background-color#5cb85c;   
  43.   }   
  44.   &.checkbox-orange:checked {   
  45.     background-color#f0ad4e;   
  46.   }   
  47.   &.checkbox-s {   
  48.     width19px;   
  49.     height19px;   
  50.     @include checkedCon(13px);   
  51.   }   
  52. }   
  53.     
  54. .mui-checkbox-anim{   
  55.   //border等其他元素不做过渡效果,增加视觉差,更有动画效果   
  56.   transition: background-color ease $duration/2;   
  57.     
  58. }  

 
带switch开关
本身我做这一个ui的目的是支持移动端的页面,而webkit上也正好支持单标记的input元素是使用伪类(:before或:after),所以我没做更多的支持和优化,我只是想尽量的保持html干净,所以没用其他元素做模拟。如果你要使用在桌面应用上,或支持其他浏览器,可以自己稍微修改一下,反正我是没测试过。

今天继续分享一个iOS风格的switch开关按钮,样子也非常常见,如图:
使用CSS3编写类似iOS中的复选框及带开关的按钮

主要是使用了<input  type="checkbox">来模拟实现,具体的HTML:

XML/HTML Code复制内容到剪贴板
  1. <label><input class="mui-switch" type="checkbox"> 默认未选中</label>  
  2. <label><input class="mui-switch" type="checkbox" checked> 默认选中</label>  
  3. <label><input class="mui-switch mui-switch-animbg" type="checkbox"> 默认未选中,简单的背景过渡效果,加mui-switch-animbg类即可</label>  
  4. <label><input class="mui-switch mui-switch-animbg" type="checkbox" checked> 默认选中</label>  
  5. <label><input class="mui-switch mui-switch-anim" type="checkbox"> 默认未选中,过渡效果,加 mui-switch-anim   
  6. 类即可</label>  
  7. <label><input class="mui-switch mui-switch-anim" type="checkbox" checked> 默认选中</label>  

在实际的使用中后来又增加了两个过渡效果,分别加 mui-switch-animbg和mui-switch-anim 类即可,具体效果查看下面的demo页面。

CSS代码(SCSS导出的,排版有些奇怪):

CSS Code复制内容到剪贴板
  1. .mui-switch {   
  2.   width52px;   
  3.   height31px;   
  4.   positionrelative;   
  5.   border1px solid #dfdfdf;   
  6.   background-color#fdfdfd;   
  7.   box-shadow: #dfdfdf 0 0 0 0 inset;   
  8.   border-radius: 20px;   
  9.   border-top-left-radius: 20px;   
  10.   border-top-rightright-radius: 20px;   
  11.   border-bottom-left-radius: 20px;   
  12.   border-bottom-rightright-radius: 20px;   
  13.   background-clipcontent-box;   
  14.   displayinline-block;   
  15.   -webkit-appearance: none;   
  16.   user-select: none;   
  17.   outlinenone; }   
  18.   .mui-switch:before {   
  19.     content'';   
  20.     width29px;   
  21.     height29px;   
  22.     positionabsolute;   
  23.     top0px;   
  24.     left: 0;   
  25.     border-radius: 20px;   
  26.     border-top-left-radius: 20px;   
  27.     border-top-rightright-radius: 20px;   
  28.     border-bottom-left-radius: 20px;   
  29.     border-bottom-rightright-radius: 20px;   
  30.     background-color#fff;   
  31.     box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4); }   
  32.   .mui-switch:checked {   
  33.     border-color#64bd63;   
  34.     box-shadow: #64bd63 0 0 0 16px inset;   
  35.     background-color#64bd63; }   
  36.     .mui-switch:checked:before {   
  37.       left21px; }   
  38.   .mui-switch.mui-switch-animbg {   
  39.     transition: background-color ease 0.4s; }   
  40.     .mui-switch.mui-switch-animbg:before {   
  41.       transition: left 0.3s; }   
  42.     .mui-switch.mui-switch-animbg:checked {   
  43.       box-shadow: #dfdfdf 0 0 0 0 inset;   
  44.       background-color#64bd63;   
  45.       transition: border-color 0.4s, background-color ease 0.4s; }   
  46.       .mui-switch.mui-switch-animbg:checked:before {   
  47.         transition: left 0.3s; }   
  48.   .mui-switch.mui-switch-anim {   
  49.     transition: border cubic-bezier(0, 0, 0, 1) 0.4s, box-shadow cubic-bezier(0, 0, 0, 1) 0.4s; }   
  50.     .mui-switch.mui-switch-anim:before {   
  51.       transition: left 0.3s; }   
  52.     .mui-switch.mui-switch-anim:checked {   
  53.       box-shadow: #64bd63 0 0 0 16px inset;   
  54.       background-color#64bd63;   
  55.       transition: border ease 0.4s, box-shadow ease 0.4s, background-color ease 1.2s; }   
  56.       .mui-switch.mui-switch-anim:checked:before {   
  57.         transition: left 0.3s; }   
  58.     
  59. /*# sourceMappingURL=mui-switch.css.map */  

SCSS代码:

CSS Code复制内容到剪贴板
  1. @mixin borderRadius($radius:20px) {   
  2.   border-radius: $radius;   
  3.   border-top-left-radius: $radius;   
  4.   border-top-rightright-radius: $radius;   
  5.   border-bottom-left-radius: $radius;   
  6.   border-bottom-rightright-radius: $radius;   
  7. }   
  8.     
  9. $duration: .4s;   
  10. $checkedColor: #64bd63;   
  11. .mui-switch {   
  12.   width52px;   
  13.   height31px;   
  14.   positionrelative;   
  15.   border1px solid #dfdfdf;   
  16.   background-color#fdfdfd;   
  17.   box-shadow: #dfdfdf 0 0 0 0 inset;   
  18.   @include borderRadius();   
  19.   background-clipcontent-box;   
  20.   displayinline-block;   
  21.   -webkit-appearance: none;   
  22.   user-select: none;   
  23.   outlinenone;   
  24.   &:before {   
  25.     content'';   
  26.     width29px;   
  27.     height29px;   
  28.     positionabsolute;   
  29.     top0px;   
  30.     left: 0;   
  31.     @include borderRadius();   
  32.     background-color#fff;   
  33.     box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);   
  34.   }   
  35.   &:checked {   
  36.     border-color: $checkedColor;   
  37.     box-shadow: $checkedColor 0 0 0 16px inset;   
  38.     background-color: $checkedColor;   
  39.     &:before {   
  40.       left21px;   
  41.     }   
  42.   }   
  43.   &.mui-switch-animbg {   
  44.     transition: background-color ease $duration;   
  45.     &:before {   
  46.       transition: left 0.3s;   
  47.     }   
  48.     &:checked {   
  49.       box-shadow: #dfdfdf 0 0 0 0 inset;   
  50.       background-color: $checkedColor;   
  51.       transition: border-color $duration, background-color ease $duration;   
  52.       &:before {   
  53.         transition: left 0.3s;   
  54.       }   
  55.     }   
  56.     
  57.   }   
  58.   &.mui-switch-anim {   
  59.     transition: border cubic-bezier(0, 0, 0, 1) $duration, box-shadow cubic-bezier(0, 0, 0, 1) $duration;   
  60.     &:before {   
  61.       transition: left 0.3s;   
  62.     }   
  63.     &:checked {   
  64.       box-shadow: $checkedColor 0 0 0 16px inset;   
  65.       background-color: $checkedColor;   
  66.       transition: border ease $duration, box-shadow ease $duration, background-color ease $duration*3;   
  67.       &:before {   
  68.         transition: left 0.3s;   
  69.       }   
  70.     }   
  71.     
  72.   }   
  73. }  
HTML / CSS 相关文章推荐
css3.0 图形构成实例练习一
Mar 19 HTML / CSS
css3弹性盒模型实例介绍
May 27 HTML / CSS
CSS3实现酷炫的3D旋转透视效果
Nov 21 HTML / CSS
CSS3实现的渐变幻灯片效果
Dec 07 HTML / CSS
使用phonegap检测网络状态的方法
Mar 30 HTML / CSS
socket.io 和canvas 实现的共享画板功能
May 22 HTML / CSS
HTML5教程之html 5 本地数据库(Web Sql Database)
Apr 03 HTML / CSS
使用HTML5的表单验证的简单示例
Sep 09 HTML / CSS
整理HTML5中支持的URL编码与字符编码
Feb 23 HTML / CSS
有关HTML5中背景音乐的自动播放功能
Oct 16 HTML / CSS
html5 http的轮询和Websocket原理
Oct 19 HTML / CSS
遮罩层 + Iframe实现界面自动显示的示例代码
Apr 26 HTML / CSS
基础的CSS3弹性盒Flexbox布局使用实例
Apr 08 #HTML / CSS
CSS3的Flexbox布局的简明入门指南
Apr 08 #HTML / CSS
使用CSS3设计地图上的雷达定位提示效果
Apr 05 #HTML / CSS
简单掌握CSS3中resize属性的用法
Apr 01 #HTML / CSS
CSS3制作炫酷的自定义发光文字
Mar 28 #HTML / CSS
可自定义箭头样式的CSS3气泡提示框
Mar 16 #HTML / CSS
6种非常炫酷的CSS3按钮边框动画特效
Mar 16 #HTML / CSS
You might like
php生成二维码不保存服务器还有下载功能的实现代码
2018/08/09 PHP
Jquery实现无刷新DropDownList联动实现代码
2010/03/08 Javascript
让你的博客飘雪花超出屏幕依然看得见
2013/01/04 Javascript
JS文本框追加多个下拉框的值的简单实例
2013/07/12 Javascript
利用JavaScript实现新闻滚动效果(实例代码)
2013/11/27 Javascript
Jquery中CSS选择器用法分析
2015/02/10 Javascript
使用JavaScript实现旋转的彩圈特效
2015/06/23 Javascript
JavaScript基础知识点归纳(推荐)
2016/07/09 Javascript
Agularjs妙用双向数据绑定实现手风琴效果
2017/05/26 Javascript
详解vue跨组件通信的几种方法
2017/06/15 Javascript
vue通过路由实现页面刷新的方法
2018/01/25 Javascript
node.js之基础加密算法模块crypto详解
2018/09/11 Javascript
js隐式转换的知识实例讲解
2018/09/28 Javascript
Angular 2使用路由自定义弹出组件toast操作示例
2019/05/10 Javascript
vuex存储token示例
2019/11/11 Javascript
使用nodejs实现JSON文件自动转Excel的工具(推荐)
2020/06/24 NodeJs
[46:59]完美世界DOTA2联赛PWL S2 GXR vs Ink 第二场 11.19
2020/11/20 DOTA
Python计算斗牛游戏概率算法实例分析
2017/09/26 Python
Python2.7基于笛卡尔积算法实现N个数组的排列组合运算示例
2017/11/23 Python
DataFrame中去除指定列为空的行方法
2018/04/08 Python
Python小白必备的8个最常用的内置函数(推荐)
2019/04/03 Python
在python中利用numpy求解多项式以及多项式拟合的方法
2019/07/03 Python
python3.6生成器yield用法实例分析
2019/08/23 Python
使用虚拟环境打包python为exe 文件的方法
2019/08/29 Python
python模拟预测一下新型冠状病毒肺炎的数据
2020/02/01 Python
PyCharm MySQL可视化Database配置过程图解
2020/06/09 Python
HTML5拍照和摄像机功能实战详解
2019/01/24 HTML / CSS
土木工程应届生自荐信
2013/09/24 职场文书
学校七一活动方案
2014/01/19 职场文书
村干部承诺书
2014/03/28 职场文书
我们的节日春节活动方案
2014/08/22 职场文书
党的群众路线教育实践活动批评与自我批评范文
2014/10/16 职场文书
研究生就业推荐表导师评语
2014/12/31 职场文书
美术教师求职信范文
2015/03/20 职场文书
反邪教观后感
2015/06/11 职场文书
Android超详细讲解组件ScrollView的使用
2022/03/31 Java/Android