下拉选择框select的纯CSS替代方案

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

一:HTML

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

.代码

  1. <fieldset class="radio-container">
  2. <div class="radio-options">
  3. <div class="toggle">Choose your beer</div>
  4. <ul>
  5. <li>
  6. <input type="radio" name="my-beer" id="choice1" value="choice1">
  7. <label for="choice1">Cul Dorcha</label>
  8. </li>
  9. <li>
  10. <input type="radio" name="my-beer" id="choice2" value="choice2">
  11. <label for="choice2">Rowers Red Ale</label>
  12. </li>
  13. <li>
  14. <input type="radio" name="my-beer" id="choice3" value="choice3">
  15. <label for="choice3">Belfast Ale</label>
  16. </li>
  17. <li>
  18. <input type="radio" name="my-beer" id="choice4" value="choice4">
  19. <label for="choice4">O‘Hara Irish Stout</label>
  20. </li>
  21. </ul>
  22. </div>
  23. </fieldset>


: 逻辑草图

为了让讲解看起来更直观,我试着画了如下的草图来描述,希望表达清楚了。前端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. <!--[if (IE 8)]>
  2. <script>
  3. $(document).ready(function(){
  4. $(".radio-options li").bind("click", function() {
  5. $(this).siblings(".checked").removeClass("checked");
  6. $(this).addClass("checked");
  7. });
  8. });
  9. </script>
  10. <![endif]-->

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. ....

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

时间: 2024-10-06 14:29:10

下拉选择框select的纯CSS替代方案的相关文章

bootstrap-表单控件——下拉选择框select元素

1.运行效果如图所示 2.实现代码如下 <!DOCTYPE html> <html> <head>     <meta charset="utf-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <title>表单控件--下拉选择框select元</title>     <!-

Bootstrap 表单控件一(单行输入框input,下拉选择框select ,文本域textarea)

单行输入框,常见的文本输入框,也就是input的type属性值为text.在Bootstrap中使用input时也必须添加type类型,如果没有指定type类型,将无法得到正确的样式,因为Bootstrap框架都是通过input[type=“?”](其中?号代表type类型,比如说text类型,对应的是input[type=“text”])的形式来定义样式的. 为了让控件在各种表单风格中样式不出错,需要添加类名“form-control”,如: <form role="form"

Bootstrap系列 -- 15. 下拉选择框select

Bootstrap框架中的下拉选择框使用和原始的一致,多行选择设置multiple属性的值为multiple.Bootstrap框架会为这些元素提供统一的样式风格 <form role="form"> <div class="form-group"> <select class="form-control"> <option>1</option> <option>2</

下拉选择框select元素的定位,报错:ElementNotInteractableException

源码如图: 直接使用Select类进行选择,selector(driver.find_element_by_id("Agency")) 会提示如下信息 raise exception_class(message, screen, stacktrace) selenium.common.exceptions.ElementNotInteractableException: Message: element not interactable: Element is not currentl

CSS自定义select下拉选择框的样式(不用其他标签模拟)

CSS自定义select下拉选择框的样式(不用其他标签模拟):http://www.jb51.net/css/148841.html CSS美化选择框:http://www.cnblogs.com/shishm/archive/2012/03/02/2376759.html 1 <!DOCTYPE html> 2 <html> 3 <head lang="en"> 4 <meta charset="UTF-8"> 5

[jQueryUI] - Chosen:select下拉选择框美化插件及问题【转】

hosen 是一个支持jquery的select下拉框美化插件,它能让丑陋的.很长的select选择框变的更好看.更方便.不仅如此,它更扩展了select,增加了自动筛选的功能.它可对列表进行分组,同时也可禁用某些选择项. 先来看下插件的效果:   跟这个比起来,原来的select样式是不是弱爆了! 马上来武装我们的select吧: 1.先把js和css文件引用到网页里面去: ? 1 2 3 <link href="js/jqueryUI/chosen/chosen.css" t

第三章:Select 下拉选择框的练习

1. 练习 Select 下拉选择框的练习. 2. 针对于这样的情况,如何来定位元素: 3. 总结: 看到下拉选择框,标准的 Select 下拉框时,可以选择合适的页面元素来定位.

jQuery插件——下拉选择框

其实,之前也写过jQuery插件,今天写的是一个模拟select选择的下拉插件. 既然是jQuery插件,那么必然是依赖jQuery的了. 老规矩,直接上代码吧! ;(function () { $.fn.extend({ dropdown:function (options) { return this.each(function (i, val) { $(val).css("position", "relative"); // 设置默认参数 var opts =

jquery.chosen.js下拉选择框美化插件项目实例

由于之前使用的bootstrap-select插件是建立在bootstrap基础上的,实际使用到项目中的时候,与我们使用的ace-admin(基于bootstrap)存在样式冲突,导致下拉框的样式发生变化.为了界面的美观,不得已查资料寻找另外的插件. 使用jquery.chosen.js下拉选择框美化插件同样也能达到类似效果 完成效果如下 实现步骤如下 1.导入相关文件 <link rel="stylesheet" href="${ctxStatic}/css/chos