Come faccio a stile un
È stato utile?

Soluzione

Qui ci sono tre soluzioni:

Soluzione # 1 - aspetto: nessuno - con Internet Explorer 10 - 11 workaround ( Demo )

-

Per nascondere il set appearance: none freccia predefinito sull'elemento di selezione, quindi aggiungere la tua freccia personalizzato con background-image

select {
   -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;       /* Remove default arrow */
   background-image: url(...);   /* Add custom arrow */
}

Supporto browser:

appearance: none ha molto buon supporto del browser ( caniuse ) - ad eccezione di Internet Explorer 11 ( e successive) e Firefox 34 (e versioni successive).

Possiamo migliorare questa tecnica e aggiungere il supporto per Internet Explorer 10 e Internet Explorer 11 con l'aggiunta di

select::-ms-expand {
    display: none; /* Hide the default arrow in Internet Explorer 10 and Internet Explorer 11 */
}

Se Internet Explorer 9 è una preoccupazione, non abbiamo modo di rimuovere la freccia di default (il che significherebbe che ora avremmo due frecce), ma, potremmo usare un funky selettore di Internet Explorer 9.

Per almeno annullare la nostra freccia personalizzato -. Lasciando intatto il select freccia predefinito

/* Target Internet Explorer 9 to undo the custom arrow */
@media screen and (min-width:0\0) {
    select {
        background-image:none\9;
        padding: 5px\9;
    }
}

Tutti insieme:

select {
  margin: 50px;
  width: 150px;
  padding: 5px 35px 5px 5px;
  font-size: 16px;
  border: 1px solid #CCC;
  height: 34px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url(http://www.stackoverflow.com/favicon.ico) 96% / 15% no-repeat #EEE;
}


/* CAUTION: Internet Explorer hackery ahead */


select::-ms-expand {
    display: none; /* Remove default arrow in Internet Explorer 10 and 11 */
}

/* Target Internet Explorer 9 to undo the custom arrow */
@media screen and (min-width:0\0) {
    select {
        background: none\9;
        padding: 5px\9;
    }
}
<select>
  <option>Apples</option>
  <option selected>Pineapples</option>
  <option>Chocklate</option>
  <option>Pancakes</option>
</select>

Questa soluzione è facile ed ha un buon supporto del browser -. Dovrebbe generalmente sufficiente


Se il supporto del browser per Internet Explorer 9 (e versioni successive) e Firefox 34 (e versioni successive) è necessario quindi continuare a leggere ...

Soluzione # 2 Tronca l'elemento di selezione per nascondere la freccia di default ( demo )

-

(Per saperne di più qui)

Avvolgere l'elemento select in un div con un larghezza fissa e overflow:hidden.

Poi dare l'elemento select una larghezza di circa 20 pixel superiore al div .

Il risultato è che la freccia a discesa predefinita dell'elemento select sarà nascosto (a causa della overflow:hidden sul contenitore), ed è possibile inserire qualsiasi immagine di sfondo che si desidera a destra-mano-lato del div.

Il vantaggio di questo approccio è che è cross-browser (Internet Explorer 8 e versioni successive, WebKit e Gecko ). Tuttavia, la svantaggio di questo approccio è che le opzioni di discesa si protende sulla destra-mano-lato (dai 20 pixel che abbiamo nascosto ... perché gli elementi opzionali prendono la larghezza della selezionare elemento).

Inserire descrizione dell'immagine qui

[Va notato, tuttavia, che se l'elemento di selezione personalizzato è necessaria solo per i dispositivi mobili - allora il problema di cui sopra non si applica - a causa del modo in cui ogni telefono si apre in modo nativo select elemento. Così per il mobile, questa potrebbe essere la soluzione migliore.]

.styled select {
  background: transparent;
  width: 150px;
  font-size: 16px;
  border: 1px solid #CCC;
  height: 34px;
}
.styled {
  margin: 50px;
  width: 120px;
  height: 34px;
  border: 1px solid #111;
  border-radius: 3px;
  overflow: hidden;
  background: url(http://www.stackoverflow.com/favicon.ico) 96% / 20% no-repeat #EEE;
}
<div class="styled">
  <select>
    <option>Pineapples</option>
    <option selected>Apples</option>
    <option>Chocklate</option>
    <option>Pancakes</option>
  </select>
</div>


Se la freccia personalizzato è necessario in Firefox - prima Versione 35 -, ma non è necessario per supportare le vecchie versioni di Internet Explorer - allora continuate a leggere ...

Soluzione # 3 - Utilizzare la proprietà pointer-events ( demo )

-

(Per saperne di più qui)

L'idea è quella di sovrapporre un elemento sopra la goccia nativo freccia giù (per creare la nostra personalizzato uno) e quindi non consentire eventi del puntatore su di esso.

Vantaggio: Funziona bene in WebKit e Gecko. Sembra buono troppo (senza elementi sporgenti option).

Svantaggi: Internet Explorer (Internet Explorer 10 e verso il basso) non supporta pointer-events, che significa che non è possibile fare clic sulla freccia personalizzato. Inoltre, un altro (ovvio) svantaggio di questo metodo è che non è possibile indirizzare la vostra immagine Freccia nuovo con un effetto hover o cursore a mano, perché abbiamo eventi del puntatore solo disabili su di loro!

Tuttavia, con questo metodo è possibile utilizzare modernizzatore o commenti condizionali per rendere Internet Explorer ripristinare lo standard costruito in freccia.

NB: Essendo che Internet Explorer 10 non supporta conditional comments più: se si desidera utilizzare questo approccio, probabilmente si dovrebbe usare Modernizr . Tuttavia, è ancora possibile escludere il puntatore-eventi CSS da Internet Explorer 10 con un hack CSS descritto qui .

.notIE {
  position: relative;
  display: inline-block;
}
select {
  display: inline-block;
  height: 30px;
  width: 150px;
  outline: none;
  color: #74646E;
  border: 1px solid #C8BFC4;
  border-radius: 4px;
  box-shadow: inset 1px 1px 2px #DDD8DC;
  background: #FFF;
}
/* Select arrow styling */

.notIE .fancyArrow {
  width: 23px;
  height: 28px;
  position: absolute;
  display: inline-block;
  top: 1px;
  right: 3px;
  background: url(http://www.stackoverflow.com/favicon.ico) right / 90% no-repeat #FFF;
  pointer-events: none;
}
/*target Internet Explorer 9 and Internet Explorer 10:*/

@media screen and (min-width: 0\0) {
  .notIE .fancyArrow {
    display: none;
  }
}
<!--[if !IE]> -->
<div class="notIE">
  <!-- <![endif]-->
  <span class="fancyArrow"></span>
  <select>
    <option>Apples</option>
    <option selected>Pineapples</option>
    <option>Chocklate</option>
    <option>Pancakes</option>
  </select>
  <!--[if !IE]> -->
</div>
<!-- <![endif]-->

Altri suggerimenti

E 'possibile, ma purtroppo per lo più in browser basati su WebKit nella misura noi, come sviluppatori, richiediamo. Ecco l'esempio di stile CSS raccolte da Chrome pannello delle opzioni via built-in strumenti di sviluppo ispettore, migliorato per abbinare proprietà CSS attualmente supportati nella maggior parte dei browser moderni:

select {
    -webkit-appearance: button;
    -moz-appearance: button;
    -webkit-user-select: none;
    -moz-user-select: none;
    -webkit-padding-end: 20px;
    -moz-padding-end: 20px;
    -webkit-padding-start: 2px;
    -moz-padding-start: 2px;
    background-color: #F07575; /* Fallback color if gradients are not supported */
    background-image: url(../images/select-arrow.png), -webkit-linear-gradient(top, #E5E5E5, #F4F4F4); /* For Chrome and Safari */
    background-image: url(../images/select-arrow.png), -moz-linear-gradient(top, #E5E5E5, #F4F4F4); /* For old Firefox (3.6 to 15) */
    background-image: url(../images/select-arrow.png), -ms-linear-gradient(top, #E5E5E5, #F4F4F4); /* For pre-releases of Internet Explorer  10*/
    background-image: url(../images/select-arrow.png), -o-linear-gradient(top, #E5E5E5, #F4F4F4); /* For old Opera (11.1 to 12.0) */
    background-image: url(../images/select-arrow.png), linear-gradient(to bottom, #E5E5E5, #F4F4F4); /* Standard syntax; must be last */
    background-position: center right;
    background-repeat: no-repeat;
    border: 1px solid #AAA;
    border-radius: 2px;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    color: #555;
    font-size: inherit;
    margin: 0;
    overflow: hidden;
    padding-top: 2px;
    padding-bottom: 2px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

Quando si esegue questo codice su qualsiasi pagina all'interno di un browser basato su WebKit dovrebbe cambiare l'aspetto della casella di selezione, rimuovere standard di OS-freccia e aggiungere un PNG-freccia, mettere un po 'la spaziatura prima e dopo l'etichetta, quasi nulla si desidera.

La parte più importante è di proprietà appearance, che cambia come l'elemento si comporta.

Funziona perfettamente in quasi tutti i browser basato su WebKit, inclusi quelli mobili, anche se Gecko non supporta appearance così come WebKit, a quanto pare.

L'elemento di selezione e la sua caratteristica discesa sono difficile da stile.

per selezionare elemento da Chris Heilmann conferma quello che ha detto Ryan Dohery in un commento alla prima risposta:

  

"L'elemento di selezione fa parte del   sistema operativo, non il browser Chrome. Pertanto, è molto   inaffidabili allo stile, e non necessariamente ha senso provare   in ogni caso ".

Il più grande incoerenza che ho notato quando lo styling selezionare menù a discesa è Safari e Google Chrome di rendering (Firefox è completamente personalizzabile tramite CSS). Dopo qualche ricerca attraverso oscure profondità di Internet mi sono imbattuto nel seguente, che si risolve quasi completamente i miei scrupoli con WebKit:

Safari e Google Chrome fix :

select {
  -webkit-appearance: none;
}

Questa, tuttavia, rimuovere la freccia a discesa. È possibile aggiungere un menù a tendina con un div vicino con uno sfondo, margine negativo o posizionato in modo assoluto sulla select discesa.

* Maggiori informazioni e le altre variabili sono disponibili in proprietà CSS: -webkit-aspetto .

tag <select> può essere uno stile tramite CSS proprio come qualsiasi altro elemento HTML in una pagina HTML visualizzato in un browser. Qui di seguito è una (troppo semplice) esempio che posizionare un elemento di selezione sulla pagina e rendere il testo delle opzioni in blu.

Esempio di file HTML (selectExample.html):

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
  <title>Select Styling</title>
  <link href="selectExample.css" rel="stylesheet">
</head>
<body>
<select id="styledSelect" class="blueText">
  <option value="apple">Apple</option>
  <option value="orange">Orange</option>
  <option value="cherry">Cherry</option>
</select>
</body>
</html>

Esempio di file CSS (selectExample.css):

/* All select elements on page */
select {
  position: relative;
}

/* Style by class. Effects the text of the contained options. */
.blueText {
  color: #0000FF;
}

/* Style by id. Effects position of the select drop down. */
#styledSelect {
  left: 100px;
}

Ho avuto questo problema esatto, tranne che non ho potuto utilizzare le immagini e non è stato limitato da supporto del browser. Questo dovrebbe essere «su spec» e con la fortuna iniziare a lavorare ovunque eventualmente .

Si utilizza strati livelli di sfondo ruotata di «ritagliare» un menù a tendina, come pseudo-elementi non funzionerebbero per l'elemento di selezione.

Modifica:. In questa versione aggiornata sto usando variabili CSS e un sistema di tematizzazione piccolo

:root {
  --radius: 2px;
  --baseFg: dimgray;
  --baseBg: white;
  --accentFg: #006fc2;
  --accentBg: #bae1ff;
}

.theme-pink {
  --radius: 2em;
  --baseFg: #c70062;
  --baseBg: #ffe3f1;
  --accentFg: #c70062;
  --accentBg: #ffaad4;
}

.theme-construction {
  --radius: 0;
  --baseFg: white;
  --baseBg: black;
  --accentFg: black;
  --accentBg: orange;
}

select {
  font: 400 12px/1.3 sans-serif;
  -webkit-appearance: none;
  appearance: none;
  color: var(--baseFg);
  border: 1px solid var(--baseFg);
  line-height: 1;
  outline: 0;
  padding: 0.65em 2.5em 0.55em 0.75em;
  border-radius: var(--radius);
  background-color: var(--baseBg);
  background-image: linear-gradient(var(--baseFg), var(--baseFg)),
    linear-gradient(-135deg, transparent 50%, var(--accentBg) 50%),
    linear-gradient(-225deg, transparent 50%, var(--accentBg) 50%),
    linear-gradient(var(--accentBg) 42%, var(--accentFg) 42%);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: 1px 100%, 20px 22px, 20px 22px, 20px 100%;
  background-position: right 20px center, right bottom, right bottom, right bottom;   
}

select:hover {
  background-image: linear-gradient(var(--accentFg), var(--accentFg)),
    linear-gradient(-135deg, transparent 50%, var(--accentFg) 50%),
    linear-gradient(-225deg, transparent 50%, var(--accentFg) 50%),
    linear-gradient(var(--accentFg) 42%, var(--accentBg) 42%);
}

select:active {
  background-image: linear-gradient(var(--accentFg), var(--accentFg)),
    linear-gradient(-135deg, transparent 50%, var(--accentFg) 50%),
    linear-gradient(-225deg, transparent 50%, var(--accentFg) 50%),
    linear-gradient(var(--accentFg) 42%, var(--accentBg) 42%);
  color: var(--accentBg);
  border-color: var(--accentFg);
  background-color: var(--accentFg);
}
<select>
  <option>So many options</option>
  <option>...</option>
</select>

<select class="theme-pink">
  <option>So many options</option>
  <option>...</option>
</select>

<select class="theme-construction">
  <option>So many options</option>
  <option>...</option>
</select>

Ecco una versione che funziona in tutti i browser moderni. La chiave sta usando appearance:none che rimuove la formattazione predefinita. Dal momento che tutta la formattazione è andato, è necessario aggiungere di nuovo nella freccia che differenzia visivamente il select dall'ingresso.

Esempio di applicazione: https://jsfiddle.net/gs2q1c7p/

select:not([multiple]) {
    -webkit-appearance: none;
    -moz-appearance: none;
    background-position: right 50%;
    background-repeat: no-repeat;
    background-image: url();
    padding: .5em;
    padding-right: 1.5em
}

#mySelect {
    border-radius: 0
}
<select id="mySelect">
    <option>Option 1</option>
    <option>Option 2</option>
</select>

Il post sul blog Come modulo CSS discesa stile senza JavaScript funziona per me, ma non riesce a Opera però:

select {
  border: 0 none;
  color: #FFFFFF;
  background: transparent;
  font-size: 20px;
  font-weight: bold;
  padding: 2px 10px;
  width: 378px;
  *width: 350px;
  *background: #58B14C;
}

#mainselection {
  overflow: hidden;
  width: 350px;
  -moz-border-radius: 9px 9px 9px 9px;
  -webkit-border-radius: 9px 9px 9px 9px;
  border-radius: 9px 9px 9px 9px;
  box-shadow: 1px 1px 11px #330033;
  background: url("arrow.gif") no-repeat scroll 319px 5px #58B14C;
}
<div id="mainselection">
  <select>
    <option>Select an Option</option>
    <option>Option 1</option>
    <option>Option 2</option>
  </select>
</div>

ho avuto modo di tuo caso utilizzando Bootstrap . Questa è la soluzione più semplice che funziona:

select.form-control {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background-position: right center;
    background-repeat: no-repeat;
    background-size: 1ex;
    background-origin: content-box;
    background-image: url("");
}
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet" />
<section class="container">
  <form class="form-horizontal">
    <select class="form-control">
      <option>One</option>
      <option>Two</option>
    </select>
  </form>
</section>

. Nota: la roba Base64 è fa-chevron-down in SVG

select  {
    outline: 0;
    overflow: hidden;
    height: 30px;
    background: #2c343c;
    color: #747a80;
    border: #2c343c;
    padding: 5px 3px 5px 10px;
    -moz-border-radius: 6px;
    -webkit-border-radius: 6px;
    border-radius: 10px;
}

select option {border: 1px solid #000; background: #010;}

Nel browser moderni è relativamente indolore per lo stile della <select> in CSS. Con appearance: none l'unica parte difficile sta sostituendo la freccia (se è quello che volete). Ecco una soluzione che utilizza un data: linea URI con testo in chiaro in formato SVG:

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  
  background-repeat: no-repeat;
  background-size: 0.5em auto;
  background-position: right 0.25em center;
  padding-right: 1em;
  
  background-image: url("data:image/svg+xml;charset=utf-8, \
    <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 40'> \
      <polygon points='0,0 60,0 30,40' style='fill:black;'/> \
    </svg>");
}
<select>
  <option>Option 1</option>
  <option>Option 2</option>
</select>

<select style="font-size: 2rem;">
  <option>Option 1</option>
  <option>Option 2</option>
</select>

Il resto della styling (bordi, padding, colori, ecc) è abbastanza semplice.

Questo funziona in tutti i browser Ho appena provato (Firefox 50, Chrome 55, Riva 38, e Safari 10). Una nota su Firefox è che se si desidera utilizzare il carattere # l'URI di dati (per esempio fill: #000) è necessario sfuggire (fill: %23000).

Utilizzare la proprietà clip per ritagliare i confini e la freccia dell'elemento select, quindi aggiungere i propri stili di ricambio ai wrapper:

    <!DOCTYPE html>
    <html>
      <head>
        <style>
          select { position: absolute; clip:rect(2px 49px 19px 2px); z-index:2; }
          body > span { display:block; position: relative; width: 64px; height: 21px; border: 2px solid green;  background: url(http://www.stackoverflow.com/favicon.ico) right 1px no-repeat; }
        </style>
      </head>
      <span>
        <select>
          <option value="">Alpha</option>
          <option value="">Beta</option>
          <option value="">Charlie</option>
        </select>
      </span>
    </html>

usare un secondo selezionare con opacità pari a zero per rendere il pulsante cliccabile:

    <!DOCTYPE html>
    <html>
      <head>
        <style>
          #real { position: absolute; clip:rect(2px 51px 19px 2px); z-index:2; }
          #fake { position: absolute; opacity: 0; }
    
          body > span { display:block; position: relative; width: 64px; height: 21px; background: url(http://www.stackoverflow.com/favicon.ico) right 1px no-repeat; }
        </style>
      </head>
      <span>
        <select id="real">
          <option value="">Alpha</option>
          <option value="">Beta</option>
          <option value="">Charlie</option>
        </select>
        <select id="fake">
          <option value="">Alpha</option>
          <option value="">Beta</option>
          <option value="">Charlie</option>
        </select>
      </span>
    </html>

coordinate differiscono Webkit e altri browser, ma un @media interrogazione in grado di coprire questo.

Riferimenti

Un esempio molto bello che utilizza :after e :before per fare il trucco è in Styling Select Box con CSS3 | CSSDeck

Sì. Si può stile qualsiasi elemento HTML con il suo nome di tag, in questo modo:

select {
  font-weight: bold;
}

Naturalmente, è anche possibile utilizzare una classe CSS per lo stile che, come ogni altro elemento:

<select class="important">
  <option>Important Option</option>
  <option>Another Important Option</option>
</select>

<style type="text/css">
  .important {
    font-weight: bold;
  }
</style>

Modifica questo elemento non è raccomandato, ma se volete provare è come qualsiasi altro elemento HTML.

Modifica esempio:

/* Edit select */
select {
    /* CSS style here */
}

/* Edit option */
option {
    /* CSS style here */
}

/* Edit selected option */
/* element  attr    attr value */
option[selected="selected"] {
    /* CSS style here */
}

<select>
    <option >Something #1</option>
    <option selected="selected">Something #2</option>
    <option >Something #3</option>
</select>

È sicuramente dovrebbe fare come in Styling selezionare, optgroup e opzioni con i CSS . In molti modi, background-color e colore sono proprio quello che ci tipicamente bisogno di opzioni di stile, non l'intera selezione.

label {
    position: relative;
    display: inline-block;
}
select {
    display: inline-block;
    padding: 4px 3px 5px 5px;
    width: 150px;
    outline: none;
    color: black;
    border: 1px solid #C8BFC4;
    border-radius: 4px;
    box-shadow: inset 1px 1px 2px #ddd8dc;
    background-color: lightblue;
}

Questa utilizza un colore di sfondo per selezionare gli elementi e ho rimosso l'immagine ..

Come di Internet Explorer 10, è possibile utilizzare il ::-ms-expand pseudo elemento selettore di stile, e nascondere, il menu a discesa elemento freccia.

select::-ms-expand {
    display:none;
    /* or visibility: hidden; to keep it's space/hitbox */
}

Lo stile restante dovrebbe essere simile agli altri browser.

Ecco una forchetta base di jsfiddle di DanielD che si applica il supporto per IE10

Ecco una soluzione basata sulle mie idee preferite di questa discussione. Questo permette styling un elemento

I contenuti sono concessi in licenza ai sensi della Creative Commons.

Se trovi violazioni del copyright, puoi contattarci a info@generacodice.com per richiedere la rimozione del contenuto.

scroll top