Wie gestalte ich ein <select> Dropdown nur mit CSS?

1333

Gibt es eine <select>reine CSS-Möglichkeit, ein Dropdown zu gestalten?

Ich muss ein <select>Formular so weit wie möglich ohne JavaScript formatieren. Welche Eigenschaften kann ich dazu in CSS verwenden?

Dieser Code muss mit allen gängigen Browsern kompatibel sein:

  • Internet Explorer 6, 7 und 8
  • Feuerfuchs
  • Safari

Ich weiß, dass ich es mit JavaScript schaffen kann: Beispiel .

Und ich spreche nicht von einfachem Styling. Ich möchte wissen, was wir nur mit CSS am besten können.

Ich habe ähnliche Fragen zum Stapelüberlauf gefunden.

Und dieser auf Doctype.com.

Jitendra Vyas
quelle
1
Es gibt nicht viel auf Google gefunden. Nur js Lösung ist da
Jitendra Vyas
41
Ich halte es für eine legitime Frage, aber die Antwort lautet "Nein, nicht wirklich" oder "Nicht so, wie Sie es wollen". Aber niemand (weder ich noch) ist sich zu 100% sicher, dieses Gefühl der Zweideutigkeit kriecht unter die Haut des Lesers und die Rechtmäßigkeit der Frage wird in Frage gestellt.
ZJR
1
@ Jitendra, ich weiß, worauf du hinaus willst. Wir würden uns freuen, wenn Sie Ihre Frage expliziter stellen würden. Außerdem habe ich gefunden, wonach Sie suchen könnten. Dies ist experimentell, aber überprüfen Sie es aus: cappuccino.org/aristo/showcase
jeremyosborne
1
@jeremyosborne - Danke für die Antwort. Ich weiß, dass ich es mit Javascript schaffen kann. Ihr einfacher Link basiert auf JS. Warum ich diese Frage gestellt habe, weil ich wissen wollte, weiß jemand, was wir am besten nur mit CSS machen können
Jitendra Vyas
@ Jitendra Danke, dass du deine Frage aktualisiert hast. Das Beste, was Sie mit den Einschränkungen, die Sie haben (nur CSS und kein JS), zuverlässig tun können, ist, die Schriftart (Schriftart), die Hintergrund- und Vordergrundfarben (Text), die Rahmengröße, das Erscheinungsbild und die Farben, die Platzierung und die Größe (normalerweise über den Typ) zu ändern Einstellung durch Schriftart). Selbst dann müssen Sie wahrscheinlich einige Änderungen vornehmen, um sicherzustellen, dass die Dinge in allen Browsern gleich aussehen. Ich wünschte, ich wüsste eine bessere Antwort als diese, und vielleicht gibt es eine, die ich verpasst habe, aber ich denke nicht.
Jeremyyborne

Antworten:

1027

Hier sind drei Lösungen:

Lösung Nr. 1 - Erscheinungsbild: Keine - mit Internet Explorer 10 - 11-Problemumgehung ( Demo )

- -

Um den Standardpfeil appearance: nonefür das Auswahlelement auszublenden , fügen Sie Ihren eigenen benutzerdefinierten Pfeil mit hinzubackground-image

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

Browser-Unterstützung:

appearance: nonehat eine sehr gute Browser-Unterstützung ( caniuse ) - mit Ausnahme von Internet Explorer 11 (und höher) und Firefox 34 (und höher).

Wir können diese Technik verbessern und durch Hinzufügen Unterstützung für Internet Explorer 10 und Internet Explorer 11 hinzufügen

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

Wenn Internet Explorer 9 ein Problem darstellt, können wir den Standardpfeil nicht entfernen (was bedeuten würde, dass wir jetzt zwei Pfeile haben), aber wir könnten einen funky Internet Explorer 9-Selektor verwenden.

Um zumindest unseren benutzerdefinierten Pfeil rückgängig zu machen, lassen Sie den Standardauswahlpfeil intakt.

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

Alle zusammen:

Diese Lösung ist einfach und bietet eine gute Browserunterstützung - sie sollte im Allgemeinen ausreichen.


Wenn Browserunterstützung für Internet Explorer 9 (und höher) und Firefox 34 (und höher) erforderlich ist, lesen Sie weiter ...

Lösung 2 Schneiden Sie das Auswahlelement ab, um den Standardpfeil ( Demo ) auszublenden.

- -

(Lesen Sie hier mehr)

Wickeln Sie das selectElement in ein div mit einer festen Breite und overflow:hidden.

Geben Sie dem selectElement dann eine Breite von etwa 20 Pixel, die größer als das div ist .

Das Ergebnis ist, dass der Standard-Dropdown-Pfeil des selectElements (aufgrund des overflow:hiddenauf dem Container) ausgeblendet wird und Sie jedes gewünschte Hintergrundbild auf der rechten Seite des Div platzieren können.

Der Vorteil dieses Ansatzes besteht darin, dass er browserübergreifend ist (Internet Explorer 8 und höher, WebKit und Gecko ). Der Nachteil dieses Ansatzes ist jedoch, dass das Options-Dropdown-Menü auf der rechten Seite herausragt (um die 20 Pixel, die wir ausgeblendet haben ... weil die Optionselemente die Breite des Auswahlelements annehmen).

Geben Sie hier die Bildbeschreibung ein

[Es sollte jedoch beachtet werden, dass, wenn das benutzerdefinierte Auswahlelement nur für mobile Geräte erforderlich ist - das oben genannte Problem nicht auftritt -, da jedes Telefon das Auswahlelement nativ öffnet. Für Mobilgeräte ist dies möglicherweise die beste Lösung.]


Wenn der benutzerdefinierte Pfeil in Firefox - vor Version 35 - erforderlich ist , Sie jedoch keine alten Versionen von Internet Explorer unterstützen müssen, lesen Sie weiter ...

Lösung 3 - Verwenden Sie die pointer-eventsEigenschaft ( Demo )

- -

(Lesen Sie hier mehr)

Die Idee hier ist, ein Element über den nativen Dropdown-Pfeil zu legen (um unser benutzerdefiniertes zu erstellen) und dann Zeigerereignisse darauf zu verbieten.

Vorteil: Es funktioniert gut in WebKit und Gecko. Es sieht auch gut aus (keine hervorstehenden optionElemente).

Nachteil: Internet Explorer (Internet Explorer 10 und niedriger) wird nicht unterstützt pointer-events, dh Sie können nicht auf den benutzerdefinierten Pfeil klicken. Ein weiterer (offensichtlicher) Nachteil dieser Methode ist, dass Sie Ihr neues Pfeilbild nicht mit einem Hover-Effekt oder einem Handcursor anvisieren können, da wir gerade Zeigerereignisse deaktiviert haben!

Mit dieser Methode können Sie jedoch Modernizer oder bedingte Kommentare verwenden, um Internet Explorer auf den integrierten Standardpfeil zurückzusetzen.

NB: Da Internet Explorer 10 nicht mehr unterstützt wird conditional comments: Wenn Sie diesen Ansatz verwenden möchten, sollten Sie wahrscheinlich Modernizr verwenden . Es ist jedoch weiterhin möglich, das Zeigerereignis-CSS mit einem hier beschriebenen CSS-Hack aus Internet Explorer 10 auszuschließen .

Danield
quelle
1
Welches ist Ihrer Meinung nach das Beste aus diesen beiden Methoden?
Jitendra Vyas
3
Dies hängt von den Designanforderungen ab. Wenn Sie mit dem Herausragen von Dropdowns einverstanden sind - dann ist das das Beste, weil es browserübergreifend ist (IMO allbrowsers + IE8 + könnte als browserübergreifend angesehen werden), aber ich denke zu vielen - das geht nicht. In meiner obigen Aussage meinte ich also, dass Ansatz Nr. 2 der beste war.
Danield
4
Außerdem verwendet die Geige, die ich gepostet habe, Ansatz 2 mit bedingten Anweisungen, damit der IE seinen Standardpfeil verwenden kann.
Danield
3
@AlexisLeclerc Das Korrigieren von div und select auf die gleiche Breite funktioniert nur in -webkit-Browsern wie Chrome. (weil ich die Regel aufgenommen habe - Webkit-Erscheinungsbild: keine; ) Dies funktioniert jedoch nicht in anderen Browsern wie Firefox
Danield
4
Wenn ich eine Verbesserung für Ansatz 1 vorschlagen darf, finde ich persönlich das Fehlen eines Randes oder eines fehlenden Auswahlhalos auf der rechten Seite sehr ärgerlich. Ich habe Ihre Geige mit etwas aktualisiert, das ich in meinem aktuellen Projekt verwendet habe: jsfiddle.net/YvCHW/1745 . Sag mir was du denkst!
Alexis Leclerc
233

Es ist möglich, aber leider meistens in WebKit-basierten Browsern, soweit wir als Entwickler dies benötigen. Hier ist das Beispiel für das CSS-Styling, das im Chrome-Optionsfeld über den integrierten Inspektor für Entwicklertools erfasst wurde und an die derzeit unterstützten CSS-Eigenschaften in den meisten modernen Browsern angepasst wurde:

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

Wenn Sie diesen Code auf einer beliebigen Seite in einem WebKit-basierten Browser ausführen, sollte sich das Erscheinungsbild des Auswahlfelds ändern, der Standard-OS-Pfeil entfernt und ein PNG-Pfeil hinzugefügt werden. Stellen Sie vor und nach dem Etikett einen Abstand ein, fast alles, was Sie möchten.

Der wichtigste Teil ist die appearanceEigenschaft, die das Verhalten des Elements ändert.

Es funktioniert perfekt in fast allen WebKit-basierten Browsern, einschließlich mobilen Browsern, obwohl Gecko appearanceanscheinend nicht so gut wie WebKit unterstützt.

Matthew Morek
quelle
4
Hey, mir ist aufgefallen, dass die Auswahlfelder ab Firefox 12 sehr unterschiedlich aussahen (es sieht sehr nach Chrome aus (ich habe einen Mac)), und es scheint, dass FF 12 eine Reihe weiterer Erscheinungsattribute unterstützt.
CWSpear
3
Eine reine Chromlösung ... Ich würde weder dafür noch für meinen Kunden bezahlen. Siehe @ Dianelds Antwort für eine X-Browser-Lösung.
Adrien Be
41
@AdrienBe Meine Lösung wurde vor fast 3 Jahren vorgeschlagen; Zu dieser Zeit war dies die einzig vernünftige Möglichkeit, Auswahlfelder ohne JavaScript-Bibliotheken oder -Plugins neu zu gestalten. Es ist immer noch sinnvoll, wenn Sie die vorangestellten Attribute löschen möchten, aber es funktioniert zuverlässig nur in Webkit-basierten Browsern (also auch Safari, neues Opera + Android). Im Moment gibt es vielleicht bessere Lösungen. Statt bedeutungslose Kommentare hinzuzufügen, stimmen Sie einfach für die Lösung ab, die Sie als besser ansehen, und überprüfen Sie in Zukunft das "beantwortete" Datum. Vielen Dank.
Matthew Morek
4
@MatthewMorek: Es gab sogar vor 3 Jahren eine bessere Lösung. Daniels Antwort ist in Bezug auf die browserübergreifende Unterstützung viel besser (sie unterstützt IE8 und höher, WebKit und Gecko). Die Frage lautete: "Code muss mit allen gängigen Browsern kompatibel sein: Internet Explorer 6,7 und 8, Firefox & Safari". Diese X-Browser-Anforderung wurde möglicherweise 2013 von Paul Sweatte hinzugefügt ... Entschuldigung, wenn dies der Fall ist.
Adrien Be
3
Wenn Sie hinzufügen text-indent: 0.01px; text-overflow: "";, wird es noch besser funktionieren
Ivan
64

Das Auswahlelement und seine Dropdown-Funktion sind schwer zu formatieren .

Stilattribute für ausgewähltes Element von Chris Heilmann bestätigen, was Ryan Dohery in einem Kommentar zur ersten Antwort gesagt hat:

"Das select-Element ist Teil des Betriebssystems und nicht des Browser-Chrome. Daher ist es sehr unzuverlässig im Stil und es ist nicht unbedingt sinnvoll, es trotzdem zu versuchen."

Pavium
quelle
47

Ich hatte genau dieses Problem, außer dass ich keine Bilder verwenden konnte und nicht durch die Browserunterstützung eingeschränkt war. Dies sollte «auf Spezifikation» sein und mit etwas Glück irgendwann überall funktionieren .

Es werden geschichtete gedrehte Hintergrundebenen verwendet, um einen Dropdown-Pfeil «auszuschneiden», da Pseudoelemente für das ausgewählte Element nicht funktionieren würden.

Bearbeiten: In dieser aktualisierten Version verwende ich CSS-Variablen und ein winziges Themensystem.

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

Henrik
quelle
5
Wow, das ist eine der coolsten Lösungen, die ich je gesehen habe. Es funktioniert für mich in den neuesten Versionen von Chrome und Safari auf Mac. Wie wäre es mit anderen Browsern?
Tim und Struppi81
2
Arbeitet für mich in Firefox mit dem Zusatz von-moz-appearance: none;
Zac
45

Die größte Inkonsistenz, die ich beim Stylen ausgewählter Dropdowns festgestellt habe, ist das Rendern von Safari und Google Chrome (Firefox kann vollständig über CSS angepasst werden). Nach einigem Durchsuchen der dunklen Tiefen des Internets stieß ich auf Folgendes, das meine Bedenken mit WebKit fast vollständig löst:

Safari und Google Chrome beheben :

select {
  -webkit-appearance: none;
}

Dadurch wird jedoch der Dropdown-Pfeil entfernt. Sie können einen Dropdown-Pfeil in der Nähe divmit einem Hintergrund, einem negativen Rand oder absolut über dem ausgewählten Dropdown- Pfeil hinzufügen.

* Weitere Informationen und andere Variablen finden Sie in der CSS-Eigenschaft: -webkit-Erscheinungsbild .

ioTus
quelle
1
Vergiss nicht, dein Styling danach hinzuzufügen;) Aber ich bin sehr froh, dass ich diesen Kommentar heute gelesen habe.
Teewuane
1
Könnten Sie bitte Ihre Aussage näher erläutern: "Firefox ist über CSS vollständig anpassbar". Für mich sieht es so aus, als ob Firefox die Erscheinungseigenschaft nicht unterstützt. Wie würde dies in Firefox geschehen?
Danield
36

<select>Tags können wie jedes andere HTML-Element auf einer in einem Browser gerenderten HTML-Seite über CSS gestaltet werden. Unten finden Sie ein (zu einfaches) Beispiel, mit dem ein ausgewähltes Element auf der Seite positioniert und der Text der Optionen blau dargestellt wird.

Beispiel-HTML-Datei (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>

Beispiel-CSS-Datei (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;
}
jeremyosborne
quelle
30
Erstaunlich, dass ich zum ersten Mal "Mütter" im Internet gesehen habe, ohne dass es unhöflich war. +1 dafür!
BaL
34
Diese Antwort löst diese Frage nicht. Es werden nur Stile ausgewählt, aber nicht die Dropdown-Liste
Kyborek
14
Diese Antwort ignoriert völlig die Herausforderungen beim Erstellen einer Dropdown-Liste für eine browserübergreifende Konsistenz. Dies ist eine Antwort mit sehr geringem Aufwand.
BentOnCoding
18

Der Blog-Beitrag Wie man ein CSS-Formular im Dropdown-Stil erstellt, funktioniert kein JavaScript für mich, aber es schlägt in Opera fehl :

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>

Daniel
quelle
17

Hier ist eine Version, die in allen modernen Browsern funktioniert. Der Schlüssel wird verwendet, appearance:nonewodurch die Standardformatierung entfernt wird. Da die gesamte Formatierung weg ist, müssen Sie den Pfeil wieder hinzufügen, der die Auswahl visuell von der Eingabe unterscheidet.

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

Eric
quelle
16

Ich bin mit Bootstrap zu Ihrem Fall gekommen . Dies ist die einfachste Lösung, die funktioniert:

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>

Hinweis: Das base64-Zeug ist fa-chevron-downin SVG.

Yajo
quelle
12

In modernen Browsern ist es relativ schmerzlos, das <select>in CSS zu stylen. Mit appearance: nonedem einzigen schwierigen Teil auf den Pfeil ersetzt (wenn das , was Sie wollen). Hier ist eine Lösung, die einen Inline- data:URI mit Klartext-SVG verwendet:

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>

Der Rest des Stils (Ränder, Polster, Farben usw.) ist ziemlich einfach.

Dies funktioniert in allen Browsern, die ich gerade ausprobiert habe (Firefox 50, Chrome 55, Edge 38 und Safari 10). Ein Hinweis zu Firefox ist, dass Sie, wenn Sie das #Zeichen in der Daten-URI verwenden möchten (z. B. fill: #000), es maskieren müssen ( fill: %23000).

Kevin Christopher Henry
quelle
1
Sie können die Größe der SVG-Datei auch mit dem Attribut heightund / oder widthdem <svg>Tag anstelle der CSS-Eigenschaft festlegen background-size.
Gitaarik
10
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;}
Gecko
quelle
Mit dem aktuellen Chrome kann nichts ausgewählt werden.
Vitaly Zdanevich
9

Benutzerdefiniert Wählen Sie CSS-Stile aus

Getestet in Internet Explorer (10 und 11), Edge, Firefox und Chrome

select::-ms-expand {
  display: none;
}
select {
  display: inline-block;
  box-sizing: border-box;
  padding: 0.5em 2em 0.5em 0.5em;
  border: 1px solid #eee;
  font: inherit;
  line-height: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  appearance: none;
  background-repeat: no-repeat;
  background-image: linear-gradient(45deg, transparent 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position: right 15px top 1em, right 10px top 1em;
  background-size: 5px 5px, 5px 5px;
}
<select name="">
  <option value="">Lorem</option>
  <option value="">Lorem Ipsum</option>
</select>

<select name="" disabled>
  <option value="">Disabled</option>
</select>

<select name="" style="color:red;">
  <option value="">Color!</option>
  <option value="">Lorem Ipsum</option>
</select>

Roko C. Buljan
quelle
Etwas anpassungsfähiger (aber nicht in allen Browsern getestet):background-position: right 15px center, right 10px center;
Robin Stewart
8

Verwenden Sie die clipEigenschaft, um die Ränder und den Pfeil des selectElements zuzuschneiden, und fügen Sie dem Wrapper dann Ihre eigenen Ersatzstile hinzu:

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

Verwenden Sie eine zweite Auswahl mit einer Deckkraft von Null, um die Schaltfläche anklickbar zu machen:

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

Die Koordinaten unterscheiden sich zwischen Webkit und anderen Browsern, es handelt sich jedoch um eine @ media-Abfrage kann dies abdecken.

Verweise

Paul Sweatte
quelle
1
Funktioniert gut für mich, zumindest in Chrom: Position: absolut; Clip: Rect (2px 85px 128px 2px); Z-Index: 2; Polsterung links: 18px; Polsterung rechts: 18px; Rand: 7px Auto; Farbe: # 555; Schriftgröße: erben; Hintergrundfarbe: transparent;
BrianFreud
1
Ich habe festgestellt, dass das Abschneiden des Pfeils in IE7 nur zur Hälfte funktioniert, da Sie keine Kontrolle über den Rand der Auswahl haben.
CpILL
1
Die
Klickfunktion wurde
1
@PaulSweatte, wow, das ist dein 20. Nekromant ! Glückwunsch. Sie haben auch alle meine Fragen nach einem goldenen Nekromantenabzeichen beantwortet .
Nemo
5

Ein sehr schönes Beispiel, das den Trick verwendet :afterund :beforeausführt, ist das Styling Select Box mit CSS3 | CSSDeck

Ahmad Ajmi
quelle
1
Ja, aber die fragliche Anforderung sollte mit Internet Explorer 6,7 und 8 kompatibel sein
Jitendra Vyas
2
Ja, es ist nicht kompatibel mit IE, aber ich habe es geliebt, es für jemanden zu teilen, der nach einer modernen Lösung sucht, wie ich es gesucht habe.
Ahmad Ajmi
5

Das Bearbeiten dieses Elements wird nicht empfohlen, aber wenn Sie es ausprobieren möchten, ist es wie jedes andere HTML-Element.

Beispiel bearbeiten:

/* 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>
Homar
quelle
2
@MikkoP: Wenn Sie Änderungen vorschlagen, geben Sie bitte eine aussagekräftigere Zusammenfassung der Bearbeitung an. "Die Nachricht verbessert" ist für uns Rezensenten als allgemeine Zusammenfassung nicht sehr hilfreich. Vielen Dank.
Jean-François Corbett
1
@ Jean-FrançoisCorbett Ich werde versuchen, genauer zu sein :)
MikkoP
1
Sie können keine Optionselemente formatieren (siehe diese SO-Antwort: stackoverflow.com/a/7208814/703717 )
Danield
4
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;
}

Dies verwendet eine Hintergrundfarbe für ausgewählte Elemente und ich habe das Bild entfernt.

Glücklich
quelle
4

Ja. Sie können jedes HTML-Element anhand seines Tag-Namens wie folgt formatieren:

select {
  font-weight: bold;
}

Natürlich können Sie auch eine CSS-Klasse verwenden, um sie wie jedes andere Element zu formatieren:

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

<style type="text/css">
  .important {
    font-weight: bold;
  }
</style>
Dave Ward
quelle
6
Ich spreche nicht so, ich möchte den Dropdown-Pfeil in etwas anderes ändern
Jitendra Vyas
5
Sie können den Dropdown-Pfeil nicht auf ein anderes Bild formatieren, er wird vom Betriebssystem gesteuert. Wenn Sie es wirklich brauchen, verwenden Sie am besten ein DHTML-Dropdown-Widget.
Ryan Doherty
3
Sie können CSS-Eigenschaften nur über CSS ändern. Sie können den Rand, den Abstand, die Schrifteigenschaften, die Hintergrundfarbe usw. ändern. Wenn Sie möchten, dass es völlig anders aussieht, müssen Sie es zur Laufzeit über JavaScript durch Grafiken ersetzen (was keine gute Lösung ist, wenn es gut gemacht wird ).
Dave Ward
4

Hier ist eine Lösung, die auf meinen Lieblingsideen aus dieser Diskussion basiert. Dies ermöglicht das direkte Stylen eines <select> -Elements ohne zusätzliches Markup.

Es funktioniert mit Internet Explorer 10 (und höher) mit einem sicheren Fallback für Internet Explorer 8/9. Eine Einschränkung für diese Browser ist, dass das Hintergrundbild positioniert und klein genug sein muss, um sich hinter dem nativen Erweiterungssteuerelement zu verstecken.

HTML

<select name='options'>
  <option value='option-1'>Option 1</option>
  <option value='option-2'>Option 2</option>
  <option value='option-3'>Option 3</option>
</select>

SCSS

body {
  padding: 4em 40%;
  text-align: center;
}

select {
  $bg-color: lightcyan;
  $text-color: black;
  appearance: none; // Using -prefix-free http://leaverou.github.io/prefixfree/
  background: {
    color: $bg-color;
    image: url("https://s3-us-west-2.amazonaws.com/s.cdpn.io/1255/caret--down-15.png");
    position: right;
    repeat: no-repeat;
  }
  border: {
    color: mix($bg-color, black, 80%);
    radius: .2em;
    style: solid;
    width: 1px;
    right-color: mix($bg-color, black, 60%);
    bottom-color: mix($bg-color, black, 60%);
  }
  color: $text-color;
  padding: .33em .5em;
  width: 100%;
}

// Removes default arrow for Internet Explorer 10 (and later)
// Internet Explorer 8/9 gets the default arrow which covers the caret
// image as long as the caret image is smaller than and positioned
// behind the default arrow
select::-ms-expand {
    display: none;
}

CodePen

http://codepen.io/ralgh/pen/gpgbGx

Ralgh
quelle
3

Es gibt einen einfachen Weg.

Überprüfen Sie diese Geige und verzeihen Sie mir das Overstyling: https://jsfiddle.net/dkellner/7ac9us70/

Der Trick dahinter: Sobald das <select> -Tag eine Eigenschaft namens "size" erhält, verhält es sich wie eine Liste mit fester Höhe und ermöglicht es Ihnen plötzlich aus irgendeinem Grund, die Hölle daraus zu machen. Genau genommen ist die feste Liste ein Nebeneffekt - aber sie hilft uns nur mehr, weil wir sie für den "Dropdown-Look" verwenden.

Ein minimales Beispiel:

<style>

    .stylish span   {position:relative;}
    .stylish select {position:absolute;left:0px;display:none}

</style>
...
<div class="stylish">
    <label> Choose your superhero: </label>
    <span>
        <input onclick="$(this).closest('div').find('select').slideToggle(110)"><br>
        <select size=15 onclick="$(this).hide().closest('div').find('input').val($(this).find('option:selected').text());">

            <optgroup label="Fantasy"></optgroup>
            <option value="1">  Gandalf        </option>
            <option value="2">  Harry Potter   </option>
            <option value="3">  Jon Snow       </option>

            <!-- ... and so on -->

        </select>
    </span>
</div>

(Um es einfach zu halten, habe ich es mit jQuery gemacht - aber Sie können das gleiche auch ohne machen)

Randnotizen

  • Diese Lösung bietet Ihnen mehr als nur eine Auswahl: Der Wert kann auch manuell bearbeitet werden. Verwenden Sie die Eigenschaft readonly, wenn Sie die standardmäßige Auswahl mit eingeschränkter Auswahl bevorzugen.

  • Um die Styling-Möglichkeiten zu maximieren, werden <optgroup> -Tags nicht verwendet um ihre Kinder, sind sie bewegt , bevor sie. Es ist beabsichtigt, es ist visuell klarer und sie arbeiten gerne so, keine Sorge.

  • Javascripts: Ja, ich weiß, dass das OP "kein Javascript" sagte, aber ich habe es so verstanden, dass Sie sich bitte nicht mit Plugins beschäftigen , was in Ordnung ist. Sie brauchen keine Bibliotheken für diese. Nicht einmal jQuery, wie gesagt, es dient nur der Klarheit des Beispiels.

dkellner
quelle
2

Sie sollten es auf jeden Fall wie in Styling Select, Optgroup und Optionen mit CSS tun . In vielerlei Hinsicht sind Hintergrundfarbe und Farbe genau das, was Sie normalerweise zum Stylen von Optionen benötigen, nicht die gesamte Auswahl.

Otvazhnii
quelle
2

Sie können der Dropdown-Liste auch einen Schwebestil hinzufügen.

select {position:relative; float:left; width:21.4%; height:34px; background:#f9f9e0; border:1px solid #41533f; padding:0px 10px 0px 10px; color:#41533f; margin:-10px 0px 0px 20px; background: transparent; font-size: 12px; -webkit-appearance: none; -moz-appearance: none; appearance: none; background: url(https://alt-fit.com/images/global/select-button.png) 100% / 15% no-repeat #f9f9e0;}
select:hover {background: url(https://alt-fit.com/images/global/select-button.png) 100% / 15% no-repeat #fff;}
<html>
<head>
</head>
<body>
<select name="type" class="select"><option style="color:#41533f;" value="Select option">Select option</option>
<option value="Option 1">Option 1</option>
<option value="Option 2">Option 2</option>
<option value="Option 3">Option 3</option>
</select>
</body>
</html>


quelle
2

Die dritte Methode in Danields Antwort kann verbessert werden, um mit Hover-Effekten und anderen Mausereignissen zu arbeiten. Stellen Sie einfach sicher, dass das "button" -Element direkt nach dem select-Element im Markup steht. Richten Sie es dann mit dem + CSS-Selektor aus:

HTML:

<select class="select-input">...</select>
<div class="select-button"></div>

CSS:

.select-input:hover+.select-button {
    <Hover styles here>
}

Dies zeigt jedoch den Hover-Effekt, wenn Sie irgendwo über dem Auswahlelement schweben, nicht nur über der "Schaltfläche".

Ich verwende diese Methode in Kombination mit Angular (da mein Projekt ohnehin eine Angular-Anwendung ist), um das gesamte Auswahlelement abzudecken, und lasse Angular den Text der ausgewählten Option im "button" -Element anzeigen. In diesem Fall ist es durchaus sinnvoll, dass der Hover-Effekt angewendet wird, wenn Sie irgendwo über der Auswahl schweben.

Ohne JavaScript funktioniert dies jedoch nicht. Wenn Sie dies tun möchten und Ihre Site ohne JavaScript arbeiten muss, sollten Sie sicherstellen, dass Ihr Skript die für die Erweiterung erforderlichen Elemente und Klassen hinzufügt. Auf diese Weise erhält ein Browser ohne JavaScript einfach eine normale, nicht gestaltete Auswahl anstelle eines gestalteten Abzeichens, das nicht korrekt aktualisiert wird.

Adrian Schmidt
quelle
1
Ich würde gerne den Grund für Abstimmungen erfahren, damit ich wissen kann, wie ich mich verbessern kann! 🙂
Adrian Schmidt
1

Eine Lösung nur für CSS und HTML

Es scheint mit Chrome, Firefox und Internet Explorer 11 kompatibel zu sein. Bitte hinterlassen Sie jedoch Ihr Feedback zu anderen Webbrowsern.

Wie in Danields Antwort vorgeschlagen , verpacke ich meine Auswahl in ein Div (sogar zwei Divs aus Gründen der X-Browser-Kompatibilität), um das erwartete Verhalten zu erhalten.

Siehe http://jsfiddle.net/bjap2/

HTML:

<div class="sort-options-wrapper">
    <div class="sort-options-wrapper-2">
        <select class="sort-options">
                <option value="choiceOne">choiceOne</option>
                <option value="choiceOne">choiceThree</option>
                <option value="choiceOne">choiceFour</option>
                <option value="choiceFiveLongTestPurpose">choiceFiveLongTestPurpose</option>
        </select>
    </div>
    <div class="search-select-arrow-down"></div>
</div>

Beachten Sie die beiden Div-Wrapper.

Beachten Sie auch das zusätzliche Div, das hinzugefügt wurde, um den Pfeil nach unten zu platzieren, wo immer Sie möchten (absolut positioniert). Hier platzieren wir ihn links.

CSS

.sort-options-wrapper {
    display: inline-block;
    position: relative;
    border: 1px solid #83837F;
}

/* This second wrapper is needed for x-browser compatibility */
.sort-options-wrapper-2 {
    overflow: hidden;
}

select {
    margin-right: -19px; /* That's what is hiding the default-provided browser arrow */
    padding-left: 13px;
    margin-left: 0;
    border: none;
    background: none;

    /* margin-top & margin-bottom must be set since some
       browsers have default values for select elements */
    margin-bottom: 1px;
    margin-top: 1px;
}

select:focus {
    outline: none; /* Removing default browsers outline on focus */
}
.search-select-arrow-down {
    position: absolute;
    height: 10px;
    width: 12px;
    background: url(http://i.imgur.com/pHIYN06.png) scroll no-repeat 2px 0px;
    left: 1px;
    top: 5px;
}
Adrien Be
quelle