首頁 web前端 html教學 下拉选择框select的纯CSS替代方案_html/css_WEB-ITnose

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

Jun 24, 2016 am 11:58 AM
css select 下拉 方案 選擇

这篇教程中,我将给大家展示表单元素下拉选择框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.         
  
  •   
  •  

    二 : 逻辑草图

    为了让讲解看起来更直观,我试着画了如下的草图来描述,希望表达清楚了。前端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. ....  

     

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

    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1656
    14
    CakePHP 教程
    1415
    52
    Laravel 教程
    1309
    25
    PHP教程
    1257
    29
    C# 教程
    1229
    24
    vue中怎麼用bootstrap vue中怎麼用bootstrap Apr 07, 2025 pm 11:33 PM

    在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

    了解HTML,CSS和JavaScript:初學者指南 了解HTML,CSS和JavaScript:初學者指南 Apr 12, 2025 am 12:02 AM

    WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

    HTML,CSS和JavaScript的角色:核心職責 HTML,CSS和JavaScript的角色:核心職責 Apr 08, 2025 pm 07:05 PM

    HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

    bootstrap怎麼寫分割線 bootstrap怎麼寫分割線 Apr 07, 2025 pm 03:12 PM

    創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

    bootstrap怎麼插入圖片 bootstrap怎麼插入圖片 Apr 07, 2025 pm 03:30 PM

    在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

    bootstrap怎麼設置框架 bootstrap怎麼設置框架 Apr 07, 2025 pm 03:27 PM

    要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

    bootstrap按鈕怎麼用 bootstrap按鈕怎麼用 Apr 07, 2025 pm 03:09 PM

    如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本

    bootstrap怎麼調整大小 bootstrap怎麼調整大小 Apr 07, 2025 pm 03:18 PM

    要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

    See all articles