Rumah hujung hadapan web html tutorial 下拉选择框select的纯CSS替代方案_html/css_WEB-ITnose

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

Jun 24, 2016 am 11:58 AM
css select jatuh ke bawah rancangan pilih

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

     

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

    Kenyataan Laman Web ini
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

    Alat AI Hot

    Undresser.AI Undress

    Undresser.AI Undress

    Apl berkuasa AI untuk mencipta foto bogel yang realistik

    AI Clothes Remover

    AI Clothes Remover

    Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

    Undress AI Tool

    Undress AI Tool

    Gambar buka pakaian secara percuma

    Clothoff.io

    Clothoff.io

    Penyingkiran pakaian AI

    Video Face Swap

    Video Face Swap

    Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

    Alat panas

    Notepad++7.3.1

    Notepad++7.3.1

    Editor kod yang mudah digunakan dan percuma

    SublimeText3 versi Cina

    SublimeText3 versi Cina

    Versi Cina, sangat mudah digunakan

    Hantar Studio 13.0.1

    Hantar Studio 13.0.1

    Persekitaran pembangunan bersepadu PHP yang berkuasa

    Dreamweaver CS6

    Dreamweaver CS6

    Alat pembangunan web visual

    SublimeText3 versi Mac

    SublimeText3 versi Mac

    Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

    Cara menggunakan bootstrap di vue Cara menggunakan bootstrap di vue Apr 07, 2025 pm 11:33 PM

    Menggunakan bootstrap dalam vue.js dibahagikan kepada lima langkah: Pasang bootstrap. Import bootstrap di main.js. Gunakan komponen bootstrap secara langsung dalam templat. Pilihan: Gaya tersuai. Pilihan: Gunakan pemalam.

    Peranan HTML, CSS, dan JavaScript: Tanggungjawab Teras Peranan HTML, CSS, dan JavaScript: Tanggungjawab Teras Apr 08, 2025 pm 07:05 PM

    HTML mentakrifkan struktur web, CSS bertanggungjawab untuk gaya dan susun atur, dan JavaScript memberikan interaksi dinamik. Ketiga melaksanakan tugas mereka dalam pembangunan web dan bersama -sama membina laman web yang berwarna -warni.

    Cara Menulis Garis Pecah Di Bootstrap Cara Menulis Garis Pecah Di Bootstrap Apr 07, 2025 pm 03:12 PM

    Terdapat dua cara untuk membuat garis perpecahan bootstrap: menggunakan tag, yang mewujudkan garis perpecahan mendatar. Gunakan harta sempadan CSS untuk membuat garis perpecahan gaya tersuai.

    Memahami HTML, CSS, dan JavaScript: Panduan Pemula Memahami HTML, CSS, dan JavaScript: Panduan Pemula Apr 12, 2025 am 12:02 AM

    WebDevelopmentReliesOnhtml, CSS, andjavascript: 1) HtmlStructuresContent, 2) CSSStylesit, dan3) JavaScriptaddsInteractivity, Formingthebasisofmodernwebexperiences.

    Cara menggunakan butang bootstrap Cara menggunakan butang bootstrap Apr 07, 2025 pm 03:09 PM

    Bagaimana cara menggunakan butang bootstrap? Perkenalkan CSS bootstrap untuk membuat elemen butang dan tambahkan kelas butang bootstrap untuk menambah teks butang

    Cara mengubah saiz bootstrap Cara mengubah saiz bootstrap Apr 07, 2025 pm 03:18 PM

    Untuk menyesuaikan saiz unsur-unsur dalam bootstrap, anda boleh menggunakan kelas dimensi, yang termasuk: menyesuaikan lebar: .col-, .w-, .mw-adjust ketinggian: .h-, .min-h-, .max-h-

    Cara Menyiapkan Kerangka untuk Bootstrap Cara Menyiapkan Kerangka untuk Bootstrap Apr 07, 2025 pm 03:27 PM

    Untuk menubuhkan rangka kerja bootstrap, anda perlu mengikuti langkah -langkah ini: 1. Rujuk fail bootstrap melalui CDN; 2. Muat turun dan tuan rumah fail pada pelayan anda sendiri; 3. Sertakan fail bootstrap di HTML; 4. Menyusun sass/kurang seperti yang diperlukan; 5. Import fail tersuai (pilihan). Setelah persediaan selesai, anda boleh menggunakan sistem grid Bootstrap, komponen, dan gaya untuk membuat laman web dan aplikasi yang responsif.

    Cara memasukkan gambar di bootstrap Cara memasukkan gambar di bootstrap Apr 07, 2025 pm 03:30 PM

    Terdapat beberapa cara untuk memasukkan imej dalam bootstrap: masukkan imej secara langsung, menggunakan tag HTML IMG. Dengan komponen imej bootstrap, anda boleh memberikan imej yang responsif dan lebih banyak gaya. Tetapkan saiz imej, gunakan kelas IMG-cecair untuk membuat imej boleh disesuaikan. Tetapkan sempadan, menggunakan kelas IMG-Sempadan. Tetapkan sudut bulat dan gunakan kelas IMG-bulat. Tetapkan bayangan, gunakan kelas bayangan. Saiz semula dan letakkan imej, menggunakan gaya CSS. Menggunakan imej latar belakang, gunakan harta CSS imej latar belakang.

    See all articles