How can I remove the gloss on a select element in Safari on Mac?
Asked Answered
A

9

152

On Macs and iOS devices, in Safari, a <select> element with a background color generates a gloss over itself. This does not seem to happen in other operating systems.

For example, I have a select element with these style properties:

select {
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
border-radius: 3px;
padding: 3px 6px;
margin: 10px 0 7px;
width: 250px;
background-color: #BD2786;
color: white;
letter-spacing: -.04em;
font-weight: bold;
border: 0;
}

And my element has the background color I want, but the gloss is still there. Does anyone know how to make it a flat color?

Assuntaassur answered 3/10, 2011 at 17:47 Comment(1)
i used this - -webkit-appearance:none; and solved my issueTip
M
268

You can use this CSS property:

-webkit-appearance: none;

Note that this also causes the arrow icons to disappear. See the other answers for ways to add them back.

See http://trentwalton.com/2010/07/14/css-webkit-appearance/

Musculature answered 3/10, 2011 at 17:54 Comment(8)
Is there a way to keep the arrow on the right side? I want to override only the color. Thank youMealymouthed
@sandeep: And to make it cross-browsers: -moz-appearance: none; -webkit-appearance: none; appearance: none;Heckelphone
@Mealymouthed - As far as I can see, the only option is to re-create the arrows with background-image or unicode. #18038647Sutton
"Is there a way to keep the arrow on the right side?" No. Once you disable the appearance it kills the arrow. You can then re-create the arrow using CSS.Nedanedda
@Mealymouthed If after 3 years you're still interested.. I added a solution I found to make the arrows show.Artimas
I added the down arrow with this code and seems to work nice: background-image:url(/down_arrow.gif); background-repeat:no-repeat; background-position:calc(100% - 10px);Incite
This makes a double arrow in internet explorer 11. ideas on how to fix? Especially bad when you select a long option, because new icon will cover/obscure the option.Loyalty
The solution for IE is to use select::-ms-expand { display: none; } to hide the native IE selectbox dropdown icon, then use an actual png image as the background for the new icon. Problem occurs because SVG images aren't always positioned properly via CSS in IE.Loyalty
A
146

Using -webkit-appearance:none; will remove also the arrows indicating that this is a dropdown.

See this snippet that makes it work across different browsers an adds custom arrows without including any image files:

select{
    background: url() no-repeat 95% 50%;
    -moz-appearance: none; 
    -webkit-appearance: none; 
    appearance: none;
    /* and then whatever styles you want*/
    height: 30px; 
    width: 100px;
    padding: 5px;
}
<select>
  <option value="volvo">Volvo</option>
  <option value="saab">Saab</option>
  <option value="mercedes">Mercedes</option>
  <option value="audi">Audi</option>
</select>

If you want to additionally set the background colour of the component then add a comma and the colour at the end of the background value, e.g. ... no-repeat 95% 50%, red;

Artimas answered 4/8, 2016 at 10:18 Comment(13)
sweet, appreciate the arrows fix! here's a version with transparent background: select{ background: url() no-repeat 95% 50%; }Nagle
made a transparent arrow (couldn't paste here due to length): pastebin.com/HQ0x4RkaSouse
Cool, thx. How can i create a custom arrow? (I would like to have a single triangle)Illiquid
@Zardo If you have an SVG file, you can use b64.io to convert it to base64Artimas
I agree with your basic approach, but it's not necessary to base64 encode it (see here for more details). For a similar approach using plain-text SVG see my answer here.Ibrahim
If you have wide select elements, this will look a bit off. To fix it, you can use CSS3's background position edge offsets to better align the background. So replace no-repeat 95% 50% with no-repeat right 2px centerIncomparable
This makes a double arrow in internet explorer 11. ideas on how to fix?Loyalty
The solution for IE is to use select::-ms-expand { display: none; } to hide the native IE selectbox dropdown icon, then use an actual png image as the background for the new icon. Problem occurs because SVG images aren't always positioned properly via CSS in IE.Loyalty
The same arrows but in white and transparent pastebin.com/07iS41b5Colicweed
People beat me to customising the SVG but I see nobody here has managed to minify it! Here it's minified and the arrow fill colour is now white :) pastebin.com/r7DDqHpsApoplexy
I notice the added arrows include both an up/down arrow - any quick fix just to show the usual down arrow?Senior
Excellent. This should be the accepted answer as it's more complete. Thanks.Acanthopterygian
if you want to add a custom dropdown arrow 'glyph' style, feel free to use this background: url('') no-repeat 95% 50%;Majors
M
31

2019 Version

Shorter inline image URL, shows only down arrow, customisable arrow colour...

From https://codepen.io/jonmircha/pen/PEvqPa

Author is probably Jonathan MirCha

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='%238C98F2'><polygon points='0,0 100,0 50,50'/></svg>") no-repeat;
  background-size: 12px;
  background-position: calc(100% - 20px) center;
  background-repeat: no-repeat;
  background-color: #efefef;
}
Met answered 15/8, 2019 at 13:19 Comment(3)
The background-color property applies to the background of the select element. To change the colour of the down arrow, you need to change the SVG fill property in the URL, eg fill='%23fc0000'Met
Better to use background-position without calc: background-position: right .8em top 60%; and some cursor: is neededChaudfroid
Is there a double-arrow version of this someone can demonstrate?Kato
C
5

Sorry to pile on to an old item. I found partial answers to my questions here but had to do some work so I wanted to share my results for the next person.

I ended up using the same approach as the other contributors, but with a few tweaks to fix the following

  1. Long text was covering the arrows in the other solutions
  2. The image being used was a somewhat old and ugly up/down combo arrow.

The below will give you a working solution with the above issues fixed. Note: I used a white arrow for my use case, you may need to change the color of the arrow for yours.

here's a preview:

select with white arrow

select{    
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url() no-repeat 101% 50%;
  padding-right:20px;
}
Commensurable answered 16/11, 2018 at 17:27 Comment(2)
// , Would you mind explaining how and why that removes the gloss?Owades
The solution basically has two components: 1. Request that the browser doesn't do any style/display on the element. 2. Provide a reasonable style. In browsers that aren't god awful (read, not safari) the browser provided element style is good. In safari however the browser provide style is disgusting and terrible. Consequently we must override the browser provided display in every browser. The lines ending in appearance:none do part 1 from above. The other lines tackle part 2. Does that help?Commensurable
S
4

2022 Update

Here's a clean solution which removes the Safari gloss style by setting appearance:none and keeps the drop-down arrow, without requiring a link to an external background image.

Wrap the drop-down in a div and give it border properties in the shape of a triangle. Note that this is on the after selector of the div.

HTML:

<div class="select-dropdown">
    <select>
      <option value="Null">Favorite Fruit</option>"
      <option value="Brooklyn">Apples</option>
      <option value="Manhattan">Plums</option>
      <option value="Queens">Oranges</option>
    </select>
  </div>

CSS:

  .select-dropdown:after {
      content: " ";
      position: absolute;
      top: 50%;
      margin-top: -2px;
      right: 8px;
      width: 0;
      height: 0;
      border-left: 5px solid transparent;
      border-right: 5px solid transparent;
      border-top: 5px solid white;
   }

Credit to Flash Buddy on Codepen

Shrieve answered 8/6, 2022 at 8:43 Comment(0)
M
1

Check out -webkit-appearance: none and its derivatives. Originally described by Chris Coyer here: https://css-tricks.com/almanac/properties/a/appearance/

Matthei answered 23/5, 2016 at 16:36 Comment(0)
B
1

As mentioned several times here

-webkit-appearance:none;

also removes the arrows, which is not what you want in most cases.

An easy workaround I found is to simply use select2 instead of select. You can re-style a select2 element as well, and most importantly, select2 looks the same on Windows, Android, iOS and Mac.

Boneblack answered 31/7, 2020 at 11:46 Comment(0)
T
1

i have used this and solved my

-webkit-appearance:none;

Tip answered 25/2, 2021 at 8:19 Comment(0)
S
-7

If you inspect the User Agent StyleSheet of Chome, you'll find this

outline: -webkit-focus-ring-color auto 5px;

in short its outline property - make it None

that should remove the glow

Saar answered 9/7, 2013 at 6:42 Comment(1)
He is not asking about the outline, but the glossy background.Craw

© 2022 - 2024 — McMap. All rights reserved.