使用CSS3美化HTML表单的技巧演示


Posted in HTML / CSS onMay 17, 2016

表单是做网页中很常使用到的元素,但预设的样式都是丑丑的,笔者今天要教各位快速做出自订的单/多选框样式,让您的表单硬是要跟别人不一样。
使用CSS3美化HTML表单的技巧演示

基本 HTML 就是一个单选框元素加上标签元素:

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <h3>性别(单选)</h3>  
  3.  <div class="abgne-menu-20140101-1">  
  4.      <input type="radio" id="male" name="sex">  
  5.      <label for="male">男性</label>  
  6.     
  7.      <input type="radio" id="female" name="sex">  
  8.      <label for="female">女性</label>  
  9.     
  10.      <input type="radio" id="other" name="sex">  
  11.      <label for="other">其它</label>  
  12.  </div>  
  13. </body>  

每一个标签元素中特过 for 属性来跟单选框元素一一配对,当点击到标签元素时,则同时会触发点击到相对应的单选框。而我们不想要丑丑的单选框元素,所以笔者先用 CSS 将它隐藏起来。

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140101-1 input[type="radio"] {   
  2.  displaynone;   
  3. }  

隐藏好之后,接下来就是将标签元素进行改造一下:

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140101-1 input[type="radio"] + label {   
  2.  displayinline-block;   
  3.  background-color#ccc;   
  4.  cursorpointer;   
  5.  padding5px 10px;   
  6. }  

笔者只是做一些很简单的样式设计,同时加上自订鼠标游标为 pointer,让使用者知道它是可以点击的。

而比较特别的是 + 这个符号,它是相邻兄弟选择器(Adjacent Sibling Selector)。范例中要找的标签元素是得要跟在单选框元素后的才行,若是改成 #male + label 的话:
使用CSS3美化HTML表单的技巧演示

就真的只有在 #male 后的下一个标签元素才会有效果,其它更后面的兄弟元素则是不会有反应的唷。

好啦~现在若没问题的话,就会看到基本的样式出来了:
使用CSS3美化HTML表单的技巧演示

最后只要再搭配 :checked 拟类别(Pseudo-classes)就能收工下班啦!

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140101-1 input[type="radio"]:checked + label {   
  2.  background-color#f00;   
  3.  color#fff;   
  4. }  

这边是针对被点选到的单选框元素后的下一个标签元素进行设定。整个完成后的样式就变成了:
使用CSS3美化HTML表单的技巧演示

而多选框的自订方式也可以依此类推来设定。

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <h3>专长(多选)</h3>  
  3.  <div class="abgne-menu-20140101-2">  
  4.      <input type="checkbox" id="jquery" name="skill" checked>  
  5.      <label for="jquery">jQuery</label>  
  6.     
  7.      <input type="checkbox" id="css3" name="skill">  
  8.      <label for="css3">CSS3</label>  
  9.     
  10.      <input type="checkbox" id="html5" name="skill">  
  11.      <label for="html5">HTML5</label>  
  12.     
  13.      <input type="checkbox" id="angularjs" name="skill">  
  14.      <label for="angularjs">AngularJS</label>  
  15.  </div>  
  16. </body>  

CSS 的部份只要将 input[type="radio"] 改成 input["checkbox"] 就可以了

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140101-2 input[type="checkbox"] {   
  2.  displaynone;   
  3. }   
  4. .abgne-menu-20140101-2 input[type="checkbox"] + label {   
  5.  displayinline-block;   
  6.  background-color#ccc;   
  7.  cursorpointer;   
  8.  padding5px 10px;   
  9. }   
  10. .abgne-menu-20140101-2 input[type="checkbox"]:checked + label {   
  11.  background-color#f3d42e;   
  12. }  

是不是很简单呢~
使用CSS3美化HTML表单的技巧演示

下面则是要教大家如何凭空产生出单/多选框的元素?印?/p>

一样是一个 radio 元素加一个专属的 label 元素:

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <h3>性别(单选)</h3>  
  3.  <ul class="abgne-menu-20140109-1">  
  4.   <li>  
  5.    <input type="radio" id="male" name="sex">  
  6.       <label for="male">我是男生</label>  
  7.   </li>  
  8.   <li>  
  9.    <input type="radio" id="female" name="sex">  
  10.       <label for="female">我是女生</label>  
  11.   </li>  
  12.   <li>  
  13.    <input type="radio" id="other" name="sex">  
  14.       <label for="other">我不想说</label>  
  15.   </li>  
  16.  </ul>  
  17. </body>  

先进行基本的样式设计:

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140109-1, .abgne-menu-20140109-1 li {   
  2.  list-stylenone;   
  3.  margin5px 0;   
  4.  padding: 0;   
  5. }   
  6. .abgne-menu-20140109-1 label {   
  7.  cursorpointer;   
  8.  displayblock;   
  9.  width120px;   
  10.  positionrelative;   
  11.  line-height31px;   
  12. }   
  13. .abgne-menu-20140109-1 input[type="radio"] {   
  14.  displaynone;   
  15. }  

这些部份在用 CSS3 做表单 - 自订单/多选框样式(一)中应该都有学过吧,就只是先把 radio 元素隐藏起来。

接着,笔者要使用 ::after 拟元素(Pseudo-elements)在 lable 元素中产生用来代替单选框样式的元素:

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140109-1 label::after {   
  2.  content"No";   
  3.  displayinline-block;   
  4.  width25px;   
  5.  height25px;   
  6.  line-height25px;   
  7.  border-radius: 50%;   
  8.  padding3px;   
  9.  color#FFF;   
  10.  background#f00;   
  11.  text-aligncenter;   
  12.  margin-left10px/* 跟文字产生距离 */  
  13. }  

拟元素的内容是透过 content 属性来指定的,且一样能用 CSS 来装置它。
使用CSS3美化HTML表单的技巧演示

仔细看一下 DevTools 的画面:
使用CSS3美化HTML表单的技巧演示

虽然是叫 after,但其实是将元素产生并放置在 label 元素中,所以点击到该元素也等同点击到 label 元素。最后快来补上当 radio:checked 时的变化?樱?/p>

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140109-1 input[type="radio"]:checked + label::after {   
  2.  content"Yes";   
  3.  backgroundgreen;   
  4. }  

使用CSS3美化HTML表单的技巧演示

如果想要改放在前方时,就改换成使用 ::before:

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140109-1 label {   
  2.  cursorpointer;   
  3.  displayblock;   
  4.  width120px;   
  5.  positionrelative;   
  6.  line-height31px;   
  7.  padding-left40px/* 加上距离 */  
  8. }   
  9. .abgne-menu-20140109-1 label::before {   
  10.  content"No";   
  11.  displayinline-block;   
  12.  width25px;   
  13.  height25px;   
  14.  line-height25px;   
  15.  border-radius: 50%;   
  16.  padding3px;   
  17.  color#FFF;   
  18.  background#f00;   
  19.  text-aligncenter;   
  20.  positionabsolute;   
  21.  left: 0;   
  22. }   
  23. .abgne-menu-20140109-1 input[type="radio"]:checked + label::before {   
  24.  content"Yes";   
  25.  backgroundgreen;   
  26. }  

其中 lable 元素的 padding-left 是为了跟拟元素产生距离以免靠的太近太挤~
使用CSS3美化HTML表单的技巧演示

多选框的做法也是一样,只是将 radio 改成 checkbox 就可以了:

CSS Code复制内容到剪贴板
  1. .abgne-menu-20140109-2, .abgne-menu-20140109-2 li {   
  2.  list-stylenone;   
  3.  margin5px 0;   
  4.  padding: 0;   
  5. }   
  6. .abgne-menu-20140109-2 label {   
  7.  cursorpointer;   
  8.  displayblock;   
  9.  width120px;   
  10.  positionrelative;   
  11.  line-height31px;   
  12. }   
  13. .abgne-menu-20140109-2 label::after {   
  14.  content"No";   
  15.  displayinline-block;   
  16.  width25px;   
  17.  height25px;   
  18.  line-height25px;   
  19.  border-radius: 50%;   
  20.  padding3px;   
  21.  color#FFF;   
  22.  background#f00;   
  23.  text-aligncenter;   
  24.  positionabsolute;   
  25.  rightright: 0;   
  26. }   
  27. .abgne-menu-20140109-2 input[type="checkbox"] {   
  28.  displaynone;   
  29. }   
  30. .abgne-menu-20140109-2 input[type="checkbox"]:checked + label::after {   
  31.  content"Yes";   
  32.  backgroundgreen;   
  33. }  

有没有觉得 CSS3 真的是很强大咧~
使用CSS3美化HTML表单的技巧演示

HTML / CSS 相关文章推荐
浅析两列自适应布局的3种思路
May 03 HTML / CSS
CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)
Jun 03 HTML / CSS
CSS3实现的炫酷菜单代码分享
Mar 12 HTML / CSS
HTML5 File API改善网页上传功能
Aug 19 HTML / CSS
input元素的url类型和email类型简介
Jul 11 HTML / CSS
程序设计HTML5 Canvas API
Apr 08 HTML / CSS
HTML5几个设计和修改的页面范例分享
Sep 29 HTML / CSS
通过HTML5规范搞定i、em、b、strong元素的区别
Mar 04 HTML / CSS
HTML5响应式(自适应)网页设计的实现
Nov 17 HTML / CSS
canvas拼图功能实现代码示例
Nov 21 HTML / CSS
基于CSS制作创意端午节专属加载特效
Jun 01 HTML / CSS
利用CSS3的border-radius绘制太极及爱心图案示例
May 17 #HTML / CSS
CSS3的常见transformation图形变化用法小结
May 13 #HTML / CSS
使用CSS3的font-face字体嵌入样式的方法讲解
May 13 #HTML / CSS
几个CSS3的flex弹性盒模型布局的简单例子演示
May 12 #HTML / CSS
CSS3中的transform属性进行2D和3D变换的基本用法
May 12 #HTML / CSS
CSS3制作气泡对话框的实例教程
May 10 #HTML / CSS
详解CSS3的box-shadow属性制作边框阴影效果的方法
May 10 #HTML / CSS
You might like
用PHP和ACCESS写聊天室(九)
2006/10/09 PHP
PHP 网络开发详解之远程文件包含漏洞
2010/04/25 PHP
php结合ACCESS的跨库查询功能
2015/06/12 PHP
php计算多维数组中所有值总和的方法
2015/06/24 PHP
phpcms配置列表页以及获得文章发布时间
2017/07/04 PHP
2017年最好用的9个php开发工具推荐(超好用)
2017/10/23 PHP
document.compatMode介绍
2009/05/21 Javascript
JS运行耗时操作的延时显示方法
2010/11/19 Javascript
js实现按钮颜色渐变动画效果
2015/08/20 Javascript
javascript实现随机生成DIV背景色
2016/06/20 Javascript
JavaScript输出所选择起始与结束日期的方法
2017/07/12 Javascript
修改node.js默认的npm安装目录实例
2018/05/15 Javascript
基于vue实现滚动条滚动到指定位置对应位置数字进行tween特效
2019/04/18 Javascript
jsonp格式前端发送和后台接受写法的代码详解
2019/11/07 Javascript
Python入门教程之运算符与控制流
2016/08/17 Python
Python 12306抢火车票脚本 Python京东抢手机脚本
2018/02/06 Python
Python通过正则库爬取淘宝商品信息代码实例
2020/03/02 Python
django 取消csrf限制的实例
2020/03/13 Python
pandas分批读取大数据集教程
2020/06/06 Python
Python使用Selenium实现淘宝抢单的流程分析
2020/06/23 Python
Python获取excel内容及相关操作代码实例
2020/08/10 Python
英国安全产品购物网站:The Safe Shop
2017/03/20 全球购物
在线吉他课程,学习如何弹吉他:Fender Play
2019/02/28 全球购物
香港草莓网:Strawberrynet香港
2019/05/10 全球购物
银行毕业实习自我鉴定
2013/09/19 职场文书
实习求职信
2013/12/01 职场文书
商务英语专业求职信范文
2014/01/28 职场文书
护士在校生自荐信
2014/02/01 职场文书
优秀应届毕业生自荐书
2014/06/29 职场文书
公司门卫岗位职责范本
2014/07/08 职场文书
2014年乡镇民政工作总结
2014/12/02 职场文书
2015年党员个人工作总结
2015/05/13 职场文书
2015年迎新晚会策划书
2015/07/16 职场文书
解决Python字典查找报Keyerror的问题
2021/05/26 Python
详解Python为什么不用设计模式
2021/06/24 Python
Redis 持久化 RDB 与 AOF的执行过程
2021/11/07 Redis