How to remove the arrow from a select element in Firefox

后端 未结 30 1358
北恋
北恋 2020-11-22 15:58

I\'m trying to style a select element using CSS3. I\'m getting the results I desire in WebKit (Chrome / Safari), but Firefox isn\'t playing nicely (I\'m not ev

30条回答
  •  逝去的感伤
    2020-11-22 16:39

    hackity hack ... a solution that works in every browser I've tested (Safari, Firefox, Chrome). Don't have any IEs lying around, so it would be nice if you could test and comment:

    CSS, with url-encoded image:

    .wrapper { position:relative; width:200px; }
    .wrapper:after {
      content:"";
      display: block;
      position: absolute;
      top:1px; height:28px;
      right:1px; width:16px;
      background-image: url();
    
      pointer-events: none;
    }
    
    select {
      width: 100%;
      padding:3px;
      margin: 0;
      border-radius: 0;
      border:1px solid black;
      outline:none;
      display: inline-block;
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
      cursor:pointer;
      float:none!important;
      background:white;
    
      font-size:13px;
      line-height: 1em;
      height: 30px;
      padding:6px 20px 6px 10px;
    }
    

    http://codepen.io/anon/pen/myPEBy

    I'm using the :after-element to cover the ugly arrow. Since select doesn't support :after, i need a wrapper to work with. Now, if you would click on the arrow, the dropdown won't register it ... unless your browser supports pointer-events: none, which everyone except IE10- does: http://caniuse.com/#feat=pointer-events

    So for me it's perfect - a nice, clean, low-headache solution, at least compared to all the other options which include javascript.

    tl;dr:

    If IE10 (or lower) Users click the arrow, it won't work. Works good enough for me...

提交回复
热议问题