ie上的下拉框下拉按鈕真是太丑了,如何把他自定義一下呢?
首先,把瀏覽器自帶的下拉框去掉: select::-ms-expand { display: none; }
接下來,用自己喜歡的下拉圖片去替換:
select {
padding-right:20px;
color:#a7bce3;
appearance:none;
-moz-appearance:none;
-webkit-appearance:none;
background: rgba(21, 81, 176, 0.89) url("../../../app/img/select-icon.png") no-repeat scroll right center;
}
不過ie上比較奇葩,雖然改后樣式看起來統一了,但是點開下拉框后,鼠標滑倒每一個option上,那顏色應該是瀏覽器自己添加的,我這個背景色,瀏覽器給配的顏色是這樣的:
所以,這個方法並不能策划地解決下拉框樣式的問題,要想徹底解決,就是用、ul li來模擬下拉框。
展示如下:
代碼如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>案例測試</title> <script type="text/javascript" src="jquery.1.7.2.min.js"></script> <style> /* 公共樣式 */ * { padding: 0; margin: 0; list-style: none; font-size: 14px; } .hide { display: none; } input { outline: none; } /* 模擬下拉框 */ .select { position: relative; margin: 50px 0 0 100px; } .select .input_in input { width: 188px; height: 20px; line-height: 20px; padding: 10px 0 10px 10px; border: 1px solid #d6d6d6; cursor: pointer; } .select .city { position: absolute; top: 40px; left: 0; } .select .city ul { width: 198px; border: 1px solid #d6d6d6; border-top: none; } .select .city ul li { padding-left: 10px; width: 188px; height: 40px; line-height: 40px; cursor: pointer; } </style> </head> <body> <!-- End 模擬下拉框 --> <div class="select"> <div class="input_in"> <input type="text" value="D.C" /> </div> <div class="city hide"> <ul> <li>New York1</li> <li>New York2</li> <li>New York3</li> <li>New York4</li> <li>New York5</li> <li>New York6</li> </ul> </div> </div> <!-- End 模擬下拉框 --> <script type="text/javascript" > $(function(){ //模擬下拉框 $('.select input').on('click',function(){ if($('.select .city').is('.hide')){ $('.select .city').removeClass('hide'); }else{ $('.select .city').addClass('hide'); } }) $('.select ul li').on('click',function(){ $('.select input').val($(this).html()); $('.select .city').addClass('hide'); $('.select input').css('border-bottom','1px solid $d6d6d6'); }) $('.select ul li').hover( function(){ $(this).css({'backgroundColor':'#fd9','font-size':'18px'}); },function(){ $(this).css({'backgroundColor':'#fff','font-size':'14px'}); } ) }) </script> </body> </html>
最好再給下拉按鈕做上個下拉圖標,那就完美了。