是否有一种仅使用 CSS 的方式来设置 <select>
下拉列表的样式?
我需要尽可能多地设计一个 <select>
形式,而不需要任何 JavaScript。在 CSS 中我可以使用哪些属性来做到这一点?
此代码需要与所有主要浏览器兼容:
- Internet Explorer 6、7 和 8
- 火狐
- 苹果浏览器
我知道我可以用 JavaScript 做到这一点: Example 。
我不是在谈论简单的样式。我想知道,我们只能用 CSS 做些什么。
我在 Stack Overflow 上发现了 类似的问题。
而 这个 在 Doctype.com 上。
原文由 Jitendra Vyas 发布,翻译遵循 CC BY-SA 4.0 许可协议
以下是三种解决方案:
解决方案 #1 - 外观:无 - 使用 Internet Explorer 10 - 11 解决方法( 演示)
–
要在选择元素上隐藏默认箭头集
appearance: none
,然后添加您自己的自定义箭头background-image
浏览器支持:
appearance: none
具有很好的浏览器支持 ( caniuse ) - 除了 Internet Explorer。我们可以改进此技术并添加对 Internet Explorer 10 和 Internet Explorer 11 的支持,方法是添加
如果 Internet Explorer 9 是一个问题,我们无法删除默认箭头(这意味着我们现在有两个箭头),但是,我们可以使用时髦的 Internet Explorer 9 选择器。
至少撤消我们的自定义箭头 - 保持默认选择箭头不变。
全部一起:
这个解决方案很简单,并且有很好的浏览器支持——通常应该就足够了。
如果需要浏览器支持 Internet Explorer,请继续阅读。
解决方案 #2 截断选择元素以隐藏默认箭头( 演示)
–
(在这里阅读更多)
将
select
元素包装在具有 固定宽度 和overflow:hidden
的 div 中。然后给
select
元素一个 比 div 大大约 20 像素 的宽度。结果是
select
元素的默认下拉箭头将被隐藏(由于overflow:hidden
在容器上),您可以将任何您想要的背景图像放在div的右侧。这种方法的 优点 是它是跨浏览器的(Internet Explorer 8 及更高版本、 WebKit 和 Gecko )。然而,这种方法的 缺点 是选项下拉列表在右侧突出(我们隐藏了 20 个像素……因为选项元素占用了选择元素的宽度)。
[然而,应该注意的是,如果自定义选择元素仅对 移动 设备是必需的——那么上述问题不适用——因为每部手机本机打开选择元素的方式。所以对于移动端,这可能是最好的解决方案。]
如果自定义箭头在 Firefox 上是必需的 - 在 版本 35 之前 - 但你不需要支持旧版本的 Internet Explorer - 然后继续阅读……
解决方案 #3 - 使用
pointer-events
属性( 演示)–
(在这里阅读更多)
这里的想法是在本机下拉箭头上覆盖一个元素(以创建我们的自定义箭头),然后禁止其上的指针事件。
优点: 它在 WebKit 和 Gecko 中运行良好。它看起来也不错(没有突出
option
元素)。缺点: Internet Explorer(Internet Explorer 10 及以下)不支持
pointer-events
,这意味着您无法单击自定义箭头。此外,此方法的另一个(明显的)缺点是您无法使用悬停效果或手形光标来定位新箭头图像,因为我们刚刚禁用了它们的指针事件!但是,使用此方法,您可以使用 Modernizer 或条件注释使 Internet Explorer 恢复为标准内置箭头。
注意: 由于 Internet Explorer 10 不再支持
conditional comments
:如果你想使用这种方法,你应该使用 Modernizr 。但是,仍然可以使用 此处 描述的 CSS hack 从 Internet Explorer 10 中排除指针事件 CSS。