html - CSS 选择框箭头样式

标签 html css

我想从选择框中删除默认箭头并使用自定义图标。从之前关于 SO 的回答中,我发现这是不可能的(让它与主流浏览器一起工作)。唯一的可能性是将 select 包裹在一个 div 中,并将其宽度设置为大于 div 宽度并设置溢出:隐藏。 我正在尝试关注,但它不起作用。我做错了什么?

.selectParent {
  width: 80px;
  overflow: hidden;
}

.selectParent select {
  width: 100px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 2px 30px 2px 2px;
  border: none;
  background: transparent url("http://cdn1.iconfinder.com/data/icons/cc_mono_icon_set/blacks/16x16/br_down.png") no-repeat right center;
}
<div class="selectParent">
  <select>
    <option value="1">Option 1</option>
    <option value="2">Option 2</option>           
   </select>
</div>

JSFiddle: http://jsfiddle.net/gcPmC/

最佳答案

请按照以下方式操作:

.selectParent {
	width:120px;
	overflow:hidden;   
}
.selectParent select { 
	display: block;
	width: 100%;
	padding: 2px 25px 2px 2px; 
	border: none; 
	background: url("http://cdn1.iconfinder.com/data/icons/cc_mono_icon_set/blacks/16x16/br_down.png") right center no-repeat; 
	appearance: none; 
	-webkit-appearance: none;
	-moz-appearance: none; 
}
.selectParent.left select {
	direction: rtl;
	padding: 2px 2px 2px 25px;
	background-position: left center;
}
/* for IE and Edge */ 
select::-ms-expand { 
	display: none; 
}
<div class="selectParent">
  <select>
    <option value="1">Option 1</option>
    <option value="2">Option 2</option>           
   </select>
</div>
<br />
<div class="selectParent left">
  <select>
    <option value="1">Option 1</option>
    <option value="2">Option 2</option>           
   </select>
</div>

关于html - CSS 选择框箭头样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12668404/

相关文章:

css - 如何更改工具提示文本颜色

javascript - Electron-builder 应用程序显示 32 位空白屏幕,但适用于 64 位版本

php - 循环动态值中的表

javascript - 无法为 HTML 中的特定 DIV 添加背景图像

动画的 CSS3 过渡适用于 FF 但不适用于 Chrome,为什么?

css - Firefox 上的 Google 网络字体 Montserrat 问题 - 粗体

html - Angular 4 Output Complete HTML Syntax code in HTML as raw text

javascript - 如何在js中将html内容添加到静态文本中

javascript - 带有两个选择框、iframe 和 jQuery 的动态页面(不含 PHP)

jquery - 仅在不存在 cookie 时加载 jQuery 脚本