html select 加入css样式,css为select添加样式(无脚本)实现

博客探讨了如何通过CSS而非JavaScript插件来改变select元素的默认样式,以达到美化效果。作者提到,使用div包裹select并调整样式可以避免脚本导致的form提交后无法获取数据的问题。然而,这种方法在IE系列浏览器中存在选中项背景色块的bug,Opera下select的下拉箭头不显示。提供的代码示例展示了如何设置背景图片和边框圆角等样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

改变select默认的样式,一般情路情况下通过ul,li来模拟来实现。

有很多Jquery插件就是通过这样的方式来改变select默认样式的。

根据程序哥哥那边的反映,此种方式在form提交后无法获取数据,后来经过实验,用了不同的JS/Jquery插件,都是同样的结果:无法获取数据。

后来看一篇外国人写的 博客,用css的样式来实现 在select外面添加一个div,设置select的宽度小于父级div的宽度,然后通过设置div的background属性,改变select默认箭头的样式。

此种方法不失为一个好方法,不写脚本,只用单纯的css来实现。

不过这种方法也是有瑕疵的,就是在IE系列下,选中某个选项的时候会有背景色块,IE7-IE10都有此bug。

在Opera下,设置div的背景图不显示,也就是select的下拉箭头不显示,这个不知道是什么原因所致。

以下代码

复制代码

代码如下:

AAAAAAAAAAA

BBBBBBBBBBB

CCCCCCCCCCC

DDDDDDDDDDD

复制代码

代码如下:

.select_style {width:240px; height:30px; overflow:hidden; background:url(../images/arrow.png) no-repeat 215px;

border:1px solid #ccc;

-moz-border-radius: 5px; /* Gecko browsers */

-webkit-border-radius: 5px; /* Webkit browsers */

border-radius:5px;

}

.select_style select { padding:5px; background:transparent; width:268px; font-size: 16px; border:none; height:30px;

-webkit-appearance: none; /*for Webkit browsers*/

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值