Comment puis-je le style d'un
Était-ce utile?

La solution

Voici trois solutions:

Solution # 1 - apparence: aucun - avec Internet Explorer 10 - 11 solution de contournement ( Demo )

-

Pour masquer l'ensemble flèche par défaut appearance: none sur l'élément de sélection, puis ajoutez votre propre flèche personnalisée avec background-image

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

Support du navigateur:

appearance: none a un très bon soutien du navigateur ( caniuse ) - sauf pour Internet Explorer 11 ( et par la suite) et Firefox 34 (et plus tard).

Nous pouvons améliorer cette technique et ajouter le support pour Internet Explorer 10 et Internet Explorer 11 en ajoutant

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

Si Internet Explorer 9 est une préoccupation, nous avons aucun moyen d'enlever la flèche par défaut (ce qui voudrait dire que nous aurions maintenant deux flèches), mais nous pourrions utiliser funky sélecteur Internet Explorer 9.

Pour au moins annuler notre flèche personnalisée -. Laissant la valeur par défaut flèche de sélection intacte

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

Tous ensemble:

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>

Cette solution est facile et a un bon support du navigateur -. Il devrait généralement suffire


Si le support du navigateur pour Internet Explorer 9 (et versions ultérieures) et Firefox 34 (et versions ultérieures) est nécessaire alors continuer à lire ...

Solution # 2 tronquer l'élément de sélection pour masquer la flèche par défaut ( démo )

-

(Lire la suite)

Envelopper l'élément de select dans un div avec un largeur fixe et overflow:hidden.

Ensuite, donner à l'élément de select une largeur d'environ 20 pixels plus grand que le div .

Le résultat est que la flèche déroulante par défaut de l'élément select sera caché (en raison du overflow:hidden sur le récipient), et vous pouvez placer une image de fond que vous voulez sur la droite côté de la div.

avantage de cette approche est qu'il est multi-navigateur (Internet Explorer 8 et versions ultérieures, WebKit et Gecko ). Cependant, le désavantage de cette approche est que les options déroulantes s'avance sur la droite (par les 20 pixels que nous Hid ... parce que les éléments d'option prennent la largeur de la élément de sélection).

Entrer image description ici

[Il convient de noter toutefois que si l'élément de sélection sur mesure est nécessaire que pour appareils mobiles - le problème ci-dessus ne concerne pas - à cause de la façon dont chaque téléphone ouvre nativement la sélection élément. Donc, pour mobile, cela peut être la meilleure solution.]

.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>


Si la flèche personnalisée est nécessaire sur Firefox - avant Version 35 - mais vous n'avez pas besoin de soutenir les anciennes versions d'Internet Explorer - puis continuez à lire ...

Solution # 3 - Utilisez la propriété pointer-events ( démo )

-

(Lire la suite)

L'idée est de superposer ici un élément sur la chute native flèche vers le bas (pour créer notre commande un), puis désavouer les événements de pointeur dessus.

Avantage: Il fonctionne bien dans WebKit et Gecko. Il semble bien aussi (pas qui s'avance des éléments de option).

Inconvénient: Internet Explorer (Internet Explorer 10 et vers le bas) ne supporte pas pointer-events, ce qui signifie que vous ne pouvez pas cliquer sur la flèche personnalisée. En outre, une autre (évidente) inconvénient de cette méthode est que vous ne pouvez pas cibler votre nouvelle image flèche avec un effet de vol stationnaire ou le curseur à la main, parce que nous avons juste des événements de pointeur handicapés sur eux!

Cependant, avec cette méthode, vous pouvez utiliser Moderniser ou des commentaires conditionnels pour rendre Internet Explorer revenir à la norme construite en flèche.

NB: Etant donné que Internet Explorer 10 ne supporte pas plus conditional comments: Si vous voulez utiliser cette approche, vous devriez probablement utiliser Modernizr . Cependant, il est encore possible d'exclure le pointer-events CSS à partir d'Internet Explorer 10 avec un hack CSS décrit .

.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]-->

Autres conseils

Il est possible, mais malheureusement la plupart du temps dans les navigateurs WebKit dans la mesure où nous, en tant que développeurs, ont besoin. Voici l'exemple de style CSS recueillies à partir des options Chrome panneau par l'inspecteur des outils de développement intégré, amélioré pour correspondre aux propriétés CSS actuellement pris en charge dans la plupart des navigateurs modernes:

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;
}

Lorsque vous exécutez ce code sur une page dans un navigateur basé sur WebKit, il devrait changer l'apparence de la boîte de sélection, retirer OS-flèche standard et ajouter une flèche PNG, mettre un peu d'espacement avant et après l'étiquette, presque tout vous voulez.

La partie la plus importante est la propriété appearance, qui modifie la façon dont se comporte l'élément.

Il fonctionne parfaitement dans presque tous les navigateurs WebKit, y compris les mobiles, bien que Gecko ne supporte pas appearance ainsi que WebKit, il semble.

L'élément de sélection et sa fonction déroulant sont difficiles à coiffer.

sélectionnez par Chris Heilmann confirme ce que Ryan Dohery a dit dans un commentaire à la première réponse:

  

«L'élément de sélection est une partie de la   système d'exploitation, pas le navigateur Chrome. Par conséquent, il est très   peu fiable pour le style, et il ne fait pas nécessairement de sens d'essayer   de toute façon. "

La plus grande inconséquence que je l'ai remarqué quand styling sélectionnez dropdowns est Safari et Google Chrome rendu (Firefox est entièrement personnalisable par CSS). Après quelques recherches dans les profondeurs obscures de l'Internet, je suis tombé sur ce qui suit, ce qui résout presque complètement mes états d'âme avec WebKit:

fix Safari et Google Chrome :

select {
  -webkit-appearance: none;
}

Cela ne, cependant, retirez la flèche du menu déroulant. Vous pouvez ajouter une flèche déroulante à l'aide d'un div à proximité avec un arrière-plan, la marge négative ou position absolue sur le menu déroulant de sélection.

* Plus d'informations et d'autres variables sont disponibles dans propriété CSS: -webkit-apparence .

balises <select> peuvent être coiffés par CSS comme tout autre élément HTML sur une page HTML rendu dans un navigateur. Ci-dessous un exemple (trop simple) qui positionnera un élément de sélection sur la page et de rendre le texte des options en bleu.

Exemple de fichier 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>

Exemple de fichier 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;
}

J'ai eu ce problème exact, sauf que je ne pouvais pas utiliser les images et n'a pas été limité par le soutien du navigateur. Cela devrait être «sur spec» et avec de la chance de commencer à travailler partout éventuellement .

Il utilise des couches de fond pivotée couches à «découper» une flèche vers le bas, comme pseudo-éléments ne fonctionneraient pas pour l'élément de sélection.

Edit:. Dans cette version mise à jour j'utilise des variables CSS et un système de thématisation minuscule

: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>

Voici une version qui fonctionne dans tous les navigateurs modernes. La clé utilise appearance:none qui supprime la mise en forme par défaut. Étant donné que tous le formatage est parti, vous devez rajouter dans la flèche qui différencie visuellement la sélection de l'entrée.

Exemple de travail: 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>

Le blog Comment CSS forme déroulant le style pas JavaScript fonctionne pour moi, mais il échoue dans Opera si:

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>

Je suis arrivé à votre cas en utilisant Bootstrap . Ceci est la solution la plus simple qui fonctionne:

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>

Note:. Les choses base64 est fa-chevron-down 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;}

Dans les navigateurs modernes, il est relativement indolore pour le style de la <select> en CSS. Avec appearance: none la seule partie délicate remplace la flèche (si c'est ce que vous voulez). Voici une solution qui utilise un URI data: en ligne avec texte brut 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>

Le reste du style (bordures, rembourrage, couleurs, etc.) est assez simple.

Cela fonctionne dans tous les navigateurs que je viens d'essayer (Firefox 50, Chrome 55, dépasse 38, et Safari 10). Une note sur Firefox est que si vous voulez utiliser le caractère # dans l'URI de données (par exemple fill: #000), vous devez échapper (fill: %23000).

Utilisez la propriété clip pour rogner les frontières et la flèche de l'élément select, puis ajoutez vos propres styles de remplacement à l'emballage:

    <!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>

utiliser un second sélectionner avec zéro opacité pour rendre le bouton cliquable:

    <!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>

Coordonnées diffèrent entre Webkit et d'autres navigateurs, mais un @media requête peut couvrir que.

Références

Modifier cet élément n'est pas recommandé, mais si vous voulez essayer c'est comme tout autre élément HTML.

Exemple d'édition:

/* 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>

Vous devriez vraiment le faire comme dans Styling select, et optgroup options avec CSS . À bien des égards, couleur de fond et la couleur sont juste ce que vous généralement besoin d'options de style, pas toute la sélection.

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;
}

Il utilise une couleur d'arrière-plan pour sélectionner des éléments et je retire l'image ..

d'Internet Explorer 10, vous pouvez utiliser le ::-ms-expand sélecteur d'élément pseudo style, et se cacher, le menu déroulant élément de flèche.

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

Le style reste devrait être similaire à d'autres navigateurs.

Voici une fourchette de base de jsFiddle de DanielD qui applique le soutien IE10

Voici une solution basée sur mes idées préférées de cette discussion. Cela permet à coiffer un élément

Le contenu est autorisé sous Creative Commons.

Si vous trouvez des violations du droit d'auteur, vous pouvez nous contacter à info@generacodice.com pour demander la suppression du contenu.

scroll top