下拉选择框select的纯CSS替代方案_html/css_WEB-ITnose
这篇教程中,我将给大家展示表单元素下拉选择框select的CSS替代方案。该方法采用css来实现,看上去非常简单。我们用radio标签列表来模拟下拉列表,选择一个radio可以很好的模拟出select中选择一个元素的效果。
一:HTML
下面是我们在form表单里面用到的html代码:
.代码
- Choose your beer
二 : 逻辑草图
为了让讲解看起来更直观,我试着画了如下的草图来描述,希望表达清楚了。前端UI分享
三:CSS代码
为了让教程看起来更简洁,我省略了一部分视觉效果方面的CSS代码,(比如绘制箭头部分的CSS)-你可以在附件中查看完整版本的代码。基于同样的原因我还省略可针对不同浏览器的前缀。
radio-container的css:
.代码
- radio-container {
- position: relative;
- height: 4em; /* 3em (being the max-height of the inner container) + 1em ("margin") */
- }
- .radio-container:hover {
- z-index: 9999; }
包含在radio-container里面的元素的css: 前端UI分享
.代码
- .radio-options {
- position: absolute;
- max-height: 3em;
- width: 100%;
- overflow: hidden;
- transition: 0.7s;
- }
- .radio-options:hover {
- max-height: 100em;
- }
然后
.代码
- .radio-options .toggle {
- position: relative;
- cursor: pointer;
- padding: 0.75em;
- background: darkgreen;
- border-radius: 10px;
- z-index: 1; }
- * li are stacked at the same position as .toggle, only .toggle is visible */
- .radio-options li {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- }
- .radio-options label {
- display: block;
- opacity: 0;
- transition: 0s; }
为了隐藏了input,我们可以用display : none达到目的,但是这种方法在某些浏览器(比如一些移动浏览器)下点击label起不到聚焦相关input的作用。 前端UI分享
.代码
- .radio-options input {
- position: absolute;
- top: 0;
- left: 0;
- width: 300px;
- height: 3em;
- opacity: 0;
- z-index:1;
- cursor: pointer;
- }
四 :鼠标移上去的css代码
根据上面的代码,我们来仔细看看hover上去时发生了什么,.radio-container的z-index为一个很大的值,同时.radio-options的max-height属性也变大了(为100em),我们继续:
.代码
- /* li elements have a normal flow within the .radio-options container */
- .radio-options:hover li {
- position: relative; }
- .radio-options:hover label {
- opacity: 1;
- 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 :
.代码
- .radio-options input:checked ~ label {
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- opacity: 1;
- /* is above the .toggle so is visible */
- z-index: 2;
- /* has tha same styles as .toggle */
- padding: 0.75em;
- background: darkgreen;
- border-radius: 10px; }
On hover it returns to the normal flow
.代码
- .radio-options:hover input:checked ~ label {
- position: static;
- border-radius: 0; }
六:移动设备上所需的修正
因为我们响应的是鼠标的hover事件,所以必须针对移动设备做响应(移动设备没有鼠标)。一种解决办法是将radio 的label始终可见。我先用用自定义的modernizr build来检测触摸设备,然后添加如下的脚本:
.代码
- $(document).ready(function(){
- if (Modernizr.touch) {
- $(".radio-options").bind("click", function(event) {
- if (!($(this).parent('.radio-container').hasClass("active"))) {
- $(this).parent('.radio-container').addClass("active");
- event.stopPropagation();
- }
- });
- $(".toggle").bind("click", function(){
- $(this).parents('.radio-container').removeClass("active");
- return false;
- });
- }
- })
在css中我如下修改每一个:hover的定义: 前端UI分享
.代码
- .no-touch .radio-container:hover, .active.radio-container {
- z-index: 9999; }
- .no-touch .radio-options:hover, .active .radio-options {
- max-height: 100em;
- }
- .no-touch .radio-options:hover li, .active .radio-options li {
- position: relative; }
- .no-touch .radio-options:hover label, .active .radio-options label {
- opacity: 1;
- transition: 0.5s; }
- ....
七:IE8下如何处理
是否兼容IE8取决于你自己,这部分并不是本教程的重点
.代码
css
.代码
- .radio-options .checked label {
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- padding: 0.75em;
- background: #1b9e4d;
- visibility: visible;
- z-index: 2; }
- ....
教程结束,希望对你有所帮助,谢谢。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题











在 Vue.js 中使用 Bootstrap 分为五个步骤:安装 Bootstrap。在 main.js 中导入 Bootstrap。直接在模板中使用 Bootstrap 组件。可选:自定义样式。可选:使用插件。

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

创建 Bootstrap 分割线有两种方法:使用 标签,可创建水平分割线。使用 CSS border 属性,可创建自定义样式的分割线。

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

如何使用 Bootstrap 按钮?引入 Bootstrap CSS创建按钮元素并添加 Bootstrap 按钮类添加按钮文本

要设置 Bootstrap 框架,需要按照以下步骤:1. 通过 CDN 引用 Bootstrap 文件;2. 下载文件并将其托管在自己的服务器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根据需要编译 Sass/Less;5. 导入定制文件(可选)。设置完成后,即可使用 Bootstrap 的网格系统、组件和样式创建响应式网站和应用程序。

在 Bootstrap 中插入图片有以下几种方法:直接插入图片,使用 HTML 的 img 标签。使用 Bootstrap 图像组件,可以提供响应式图片和更多样式。设置图片大小,使用 img-fluid 类可以使图片自适应。设置边框,使用 img-bordered 类。设置圆角,使用 img-rounded 类。设置阴影,使用 shadow 类。调整图片大小和位置,使用 CSS 样式。使用背景图片,使用 background-image CSS 属性。

要调整 Bootstrap 中元素大小,可以使用尺寸类,具体包括:调整宽度:.col-、.w-、.mw-调整高度:.h-、.min-h-、.max-h-
