Como posso estilo um
Foi útil?

Solução

Aqui estão três soluções:

Solução # 1 - Aparência: none - com o Internet Explorer 10 - 11 solução ( Demonstração )

-

Para ocultar a appearance: none set seta padrão no elemento select, em seguida, adicione seu próprio costume seta com background-image

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

Suporte Browser:

appearance: none tem muito bom suporte ao navegador ( caniuse ) - exceto para o Internet Explorer 11 ( e mais tarde) e Firefox 34 (e posteriores).

Podemos melhorar esta técnica e adicionar suporte para o Internet Explorer 10 e Internet Explorer 11, adicionando

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

Se o Internet Explorer 9 é uma preocupação, não temos nenhuma maneira de remover a seta padrão (o que significaria que teríamos agora duas setas), mas, poderíamos usar um badalado Internet Explorer 9 selector.

Para, pelo menos, desfazer o nosso seta costume -. Deixando o padrão escolha arrow intacta

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

Todos juntos:

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>

Esta solução é fácil e tem bom suporte ao navegador -. Deveria geralmente bastam


Se o suporte ao navegador para o Internet Explorer 9 (e mais tarde) e Firefox 34 (e posteriores) é necessário, em seguida, continue lendo ...

Solução # 2 truncar o elemento select para ocultar a seta padrão ( demonstração )

-

(Leia mais aqui)

Enrole o elemento select em um div com um largura fixa e overflow:hidden.

Em seguida, dar o elemento select uma largura de cerca de 20 pixels maior do que a div .

O resultado é que o padrão drop-down arrow do elemento select serão ocultados (devido à overflow:hidden no recipiente), e você pode colocar qualquer imagem de fundo que você quer na mão do lado direito da div.

O vantagem dessa abordagem é que é cross-browser (Internet Explorer 8 e, mais tarde, WebKit e Gecko ). No entanto, o desvantagem desta abordagem é que as opções drop-down se projeta para fora na mão do lado direito (por 20 pixels que escondiam ... porque os elementos de opção tem a largura da selecionar elemento).

Digite os detalhes da imagem aqui

[Deve-se notar, contudo, que se o elemento select personalizado é necessária apenas para móveis dispositivos - então o problema acima não se aplica - por causa da forma como cada telefone nativamente abre a select elemento. Assim, para móveis, esta pode ser a melhor solução.]

.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 a seta costume é necessário no Firefox - antes Versão 35 - mas você não precisa para suportar versões antigas do Internet Explorer - então continue lendo ...

Solução # 3 - Use a propriedade pointer-events ( demonstração )

-

(Leia mais aqui)

A idéia aqui é para sobrepor um elemento sobre a queda nativa seta para baixo (para criar o nosso único personalizado) e eventos de ponteiro, em seguida, Invalidados em-lo.

vantagem: Ele funciona bem em WebKit e Gecko. Parece bom demais (sem que se projeta elementos option).

Desvantagem: Internet Explorer (Internet Explorer 10 e para baixo) não suporta pointer-events, o que significa que você não pode clicar na seta personalizado. Além disso, outra desvantagem (óbvio) com este método é que você não pode direcionar sua imagem seta novo com um efeito hover ou cursor lado, porque temos eventos de ponteiro apenas deficientes neles!

No entanto, com este método, você pode usar modernizador ou comentários condicionais para fazer Internet Explorer Reverter para o padrão construído em flecha.

Nota: Sendo que o Internet Explorer 10 faz mais não suporte conditional comments: Se você quiser usar essa abordagem, você provavelmente deve usar Modernizr . No entanto, ainda é possível excluir a CSS ponteiro-eventos do Internet Explorer 10 com um hack CSS descrito aqui .

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

Outras dicas

É possível, mas, infelizmente, a maioria em navegadores, na medida em que, como desenvolvedores, exigem WebKit-based. Aqui está o exemplo de estilo CSS recolhidas a partir de painel de opções Chrome via built-in ferramentas para desenvolvedores inspector, melhorou para combinar as propriedades CSS suportadas atualmente na maioria dos navegadores modernos:

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 você executar esse código em qualquer página dentro de um navegador baseado no WebKit deve alterar a aparência da caixa de seleção, remova padrão OS-flecha e adicionar um PNG de seta, coloque um pouco espaçamento antes e depois do rótulo, quase qualquer coisa você quer.

A parte mais importante é a propriedade appearance, que muda a forma como se comporta elementos.

Ele funciona perfeitamente em quase todo navegador baseado em WebKit, incluindo os móveis, embora Gecko não suporta appearance, bem como WebKit, parece.

O elemento select e sua característica suspensa são difícil de estilo.

atributos de estilo para o elemento select por Chris confirma Heilmann que Ryan Dohery disse em um comentário para a primeira resposta:

"O elemento select é parte do sistema operacional, e não o chrome browser. Portanto, é muito não confiável para o estilo, e isso não significa necessariamente fazer sentido tentar de qualquer maneira. "

A maior inconsistência tenho notado ao denominar selecione dropdowns é Safari e Google Chrome renderização (Firefox é totalmente personalizável através de CSS). Depois de algumas pesquisas através profundezas obscuras da Internet me deparei com o seguinte, que resolve quase completamente meus escrúpulos com WebKit:

Safari e Google Chrome correção :

select {
  -webkit-appearance: none;
}

Isso, no entanto, remover a seta suspensa. Você pode adicionar uma lista suspensa seta usando uma div nas proximidades, com um fundo, margem negativa ou absolutamente posicionado sobre o selecione suspensa.

* Mais informações e outras variáveis ??estão disponíveis em propriedade CSS: -webkit-appearance .

marcas <select> pode ser denominado por meio de CSS como qualquer outro elemento HTML em uma página HTML processado em um navegador. Abaixo está um (excessivamente simples) exemplo que irá posicionar um elemento select na página e tornar o texto das opções em azul.

Exemplo de arquivo 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>

arquivo CSS Exemplo (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;
}

Eu tive esse problema exato, só que eu não poderia usar imagens e não foi limitado pelo suporte ao navegador. Este deve ser «em spec» e com sorte começar a trabalhar em todos os lugares , eventualmente .

Ele usa camadas de fundo rodado em camadas para «cortado» uma lista suspensa seta, como pseudo-elementos não funcionaria para o elemento select.

Editar:. Nesta versão atualizada Eu estou usando variáveis ??CSS e um sistema theming pequena

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

Aqui está uma versão que funciona em todos os navegadores modernos. A chave é usar appearance:none que remove a formatação padrão. Desde toda a formatação é ido, você tem que adicionar novamente na seta que visualmente diferencia a escolha da entrada.

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

O post Como formulário CSS drop down estilo sem JavaScript funciona para mim, mas falha em Opera entanto:

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>

Eu tenho que seu caso usando Bootstrap . Esta é a solução mais simples que funciona:

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: o material base64 é fa-chevron-down em 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;}

Em navegadores modernos é relativamente indolor ao estilo <select> em CSS. Com appearance: none a única parte complicada é substituir a seta (se é isso que você quiser). Aqui está uma solução que utiliza um data: linha URI com SVG de texto simples:

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>

O resto do styling (fronteiras, Enchimento, cores, etc.) é bastante simples.

Isso funciona em todos os navegadores que eu apenas tentei (Firefox 50, Chrome 55, Borda 38, e Safari 10). Uma nota sobre o Firefox é que se você quiser usar o personagem # nos dados URI (por exemplo fill: #000) que você precisa para escapar dela (fill: %23000).

Use a propriedade clip para cortar as bordas e a seta do elemento select, em seguida, adicionar seus próprios estilos de substituição para o 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>

Use uma segunda escolha com opacidade zero para fazer o botão clicável:

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

Coordenadas diferem entre Webkit e outros navegadores, mas um @media consulta pode cobrir isso.

Referências

Um exemplo muito bom que usos :after e :before para fazer o truque está em Styling Select Box com CSS3 | CSSDeck

Sim. Você pode estilo qualquer elemento HTML pelo seu nome de marca, como este:

select {
  font-weight: bold;
}

É claro, você também pode usar uma classe CSS para o estilo que, como qualquer outro elemento:

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

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

Editar este elemento não é recomendado, mas se você quiser tentar é como qualquer outro elemento HTML.

Editar exemplo:

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

Você definitivamente deve fazê-lo como no Styling selecionar, optgroup e opções com CSS . De muitas maneiras, background-color e cor são apenas o que você normalmente precisa opções de estilo, não todo o seleccionar.

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

Este usa uma cor de fundo para selecionar elementos e tirei a imagem ..

A partir do Internet Explorer 10, você pode usar o ::-ms-expand pseudo elemento selector de estilo, e se esconder, o drop-down elemento seta.

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

O styling restante deve ser semelhante a outros navegadores.

Aqui está um garfo básica de jsFiddle de DanielD que se aplica o suporte para IE10

Aqui está uma solução baseada em minhas idéias favoritas de esta discussão. Isso permite denominar um elemento

O conteúdo é licenciado no Creative Commons.

Se você encontrar violações de direitos autorais, poderá entrar em contato conosco em info@generacodice.com para solicitar a remoção do conteúdo.

scroll top