下拉选择框select的纯CSS替代方案_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:58:17
原创
1580人浏览过

这篇教程中,我将给大家展示表单元素下拉选择框select的css替代方案。该方法采用css来实现,看上去非常简单。我们用radio标签列表来模拟下拉列表,选择一个radio可以很好的模拟出select中选择一个元素的效果。

一:HTML

下面是我们在form表单里面用到的html代码:

.代码 

  1.   
  2.         
      
  3.                 
    Choose your beer
      
  4.                 
        
  5.                         
  6.   
  7.                                   
  8.                                   
  9.                         
  10.   
  11.                         
  12.   
  13.                                   
  14.                                   
  15.                         
  16.   
  17.                         
  18.   
  19.                                   
  20.                                   
  21.                         
  22.   
  23.                         
  24.   
  25.                                   
  26.                                   
  27.                         
  28.   
  29.                   
  30.         
  
  •   
  •  

    卡拉OK视频制作
    卡拉OK视频制作

    卡拉OK视频制作,在几分钟内制作出你的卡拉OK视频

    卡拉OK视频制作178
    查看详情 卡拉OK视频制作

    二 : 逻辑草图

    立即学习前端免费学习笔记(深入)”;

    为了让讲解看起来更直观,我试着画了如下的草图来描述,希望表达清楚了。前端UI分享

    三:CSS代码

    为了让教程看起来更简洁,我省略了一部分视觉效果方面的CSS代码,(比如绘制箭头部分的CSS)-你可以在附件中查看完整版本的代码。基于同样的原因我还省略可针对不同浏览器的前缀。

    radio-container的css:

    .代码 

    1. radio-container {  
    2.   position: relative;  
    3.   height: 4em; /* 3em (being the max-height of the inner container) + 1em ("margin") */  
    4.  }  
    5. .radio-container:hover {  
    6.     z-index: 9999; }  

     

    包含在radio-container里面的元素的css: 前端UI分享

    .代码 

    1. .radio-options {  
    2.   position: absolute;  
    3.   max-height: 3em;  
    4.   width: 100%;  
    5.   overflow: hidden;  
    6.   transition: 0.7s;  
    7. }  
    8. .radio-options:hover {  
    9.   max-height: 100em;  
    10. }  

     

    然后

    .代码 

    1. .radio-options .toggle {  
    2.    position: relative;  
    3.    cursor: pointer;  
    4.    padding: 0.75em;  
    5.    background: darkgreen;  
    6.    border-radius: 10px;  
    7.    z-index: 1; }  
    8. * li are stacked at the same position as .toggle, only .toggle is visible */  
    9.  .radio-options li {  
    10.    position: absolute;  
    11.    top: 0;  
    12.    left: 0;  
    13.    width: 100%;  
    14.    height: 100%;  
    15.  }  
    16.  .radio-options label {  
    17.    display: block;  
    18.    opacity: 0;  
    19.    transition: 0s; }  

     

    为了隐藏了input,我们可以用display : none达到目的,但是这种方法在某些浏览器(比如一些移动浏览器)下点击label起不到聚焦相关input的作用。 前端UI分享

    .代码 

    1. .radio-options input {  
    2.   position: absolute;  
    3.   top: 0;  
    4.   left: 0;  
    5.   width: 300px;  
    6.   height: 3em;  
    7.   opacity: 0;  
    8.   z-index:1;  
    9.   cursor: pointer;  
    10. }  

     

    四 :鼠标移上去的css代码

    根据上面的代码,我们来仔细看看hover上去时发生了什么,.radio-container的z-index为一个很大的值,同时.radio-options的max-height属性也变大了(为100em),我们继续:

    .代码 

    1. /* li elements have a normal flow within the .radio-options container */  
    2. .radio-options:hover li {  
    3.     position: relative; }  
    4. .radio-options:hover label {  
    5.     opacity: 1;  
    6.     transition: 0.5s; }  

     

    五:选中状态

    To style the checked option we will use the general sibling selector. It uses a tilde character combinator (E ~ F) and matches elements that are siblings of a given element. The first element (E) has to occur before the second (F) one and they have to share the same parent (li items in our case).前端UI分享


    If one of the radio is checked, we’ll see its label instead of the toggle :

    .代码 

    1. .radio-options input:checked ~ label {  
    2.    position: absolute;  
    3.    top: 0;  
    4.    left: 0;  
    5.    right: 0;  
    6.    opacity: 1;  
    7. /* is above the .toggle so is visible */  
    8.    z-index: 2;  
    9. /* has tha same styles as .toggle */  
    10.    padding: 0.75em;  
    11.    background: darkgreen;  
    12.    border-radius: 10px; }  

     

    On hover it returns to the normal flow

    .代码 

    1. .radio-options:hover input:checked ~ label {  
    2.   position: static;  
    3.   border-radius: 0; }  

     

    六:移动设备上所需的修正

    因为我们响应的是鼠标的hover事件,所以必须针对移动设备做响应(移动设备没有鼠标)。一种解决办法是将radio 的label始终可见。我先用用自定义的modernizr build来检测触摸设备,然后添加如下的脚本:

    .代码 

    1. $(document).ready(function(){  
    2.         if (Modernizr.touch) {  
    3.                         $(".radio-options").bind("click", function(event) {  
    4.                                 if (!($(this).parent('.radio-container').hasClass("active")))   {  
    5.                                 $(this).parent('.radio-container').addClass("active");  
    6.                                 event.stopPropagation();  
    7.                                 }  
    8.                         });      
    9.         $(".toggle").bind("click", function(){  
    10.                 $(this).parents('.radio-container').removeClass("active");  
    11.                 return false;  
    12.                  });   
    13.         }  
    14. })  

     

    在css中我如下修改每一个:hover的定义: 前端UI分享

    .代码 

    1. .no-touch .radio-container:hover, .active.radio-container  {  
    2.     z-index: 9999; }  
    3. .no-touch .radio-options:hover, .active .radio-options {  
    4.   max-height: 100em;  
    5. }  
    6. .no-touch .radio-options:hover li,  .active .radio-options li {  
    7.     position: relative; }  
    8. .no-touch .radio-options:hover label, .active .radio-options label {  
    9.     opacity: 1;  
    10.     transition: 0.5s; }  
    11. ....  

     

    七:IE8下如何处理

    是否兼容IE8取决于你自己,这部分并不是本教程的重点

    .代码 

    1.   

     

    css

    .代码 

    1. .radio-options .checked label {  
    2.   position: absolute;  
    3.   top: 0;  
    4.   left: 0;  
    5.   right: 0;  
    6.   padding: 0.75em;  
    7.   background: #1b9e4d;  
    8.   visibility: visible;  
    9.   z-index: 2; }  
    10. ....  

     

    教程结束,希望对你有所帮助,谢谢。

    相关标签:
    css
    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    热门推荐
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习
    PHP中文网抖音号
    发现有趣的

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号