Wie kann ich den Stil des Kontrollkästchens (Eingabe) ändern? Ich habe border:1px solid #1e5180
es angelegt, aber in FireFox 3.5 passiert nichts!
122
Wenn in einem Browser etwas passiert, wäre ich überrascht. Dies ist eines dieser herausragenden Formularelemente, bei denen Browser in der Regel nicht so viel stylen lassen und die normalerweise von Menschen durch Javascript ersetzt werden, damit sie etwas stylen / codieren können, das wie ein Kontrollkästchen aussieht und sich verhält.
Ich schlage vor, "Gliederung" anstelle von "Grenze" zu verwenden. Zum Beispiel :
outline: 1px solid #1e5180
.quelle
!important
Ihrem CSS hinzufügen , wenn Sie Gliederung verwenden. Ich habe dies in Firefox 12.0 getestet und ohne! Wichtig würde der Umriss verschwinden, solange ich auf das Kontrollkästchen klickte.Du solltest benutzen
Dann entfernen Sie das Standard-Kontrollkästchen Bild / Stil und können es formatieren. Auf jeden Fall wird es in Firefox noch eine Grenze geben
quelle
Sie können Kastenschatten verwenden, um einen Rand zu fälschen:
quelle
Hier ist eine reine browserübergreifende CSS-Lösung (keine Bilder), die auf Martins benutzerdefinierten Kontrollkästchen und Optionsfeldern mit CSS3-LINK basiert: http://martinivanov.net/2012/12/21/imageless-custom-checkboxes-and-radio-buttons -with-css3-revisited /
Hier ist eine jsFiddle: http://jsfiddle.net/DJRavine/od26wL6n/
Ich habe dies in folgenden Browsern getestet:
quelle
Ich bin veraltet, ich weiß. Aber eine kleine Problemumgehung wäre, Ihr Kontrollkästchen in ein Etiketten-Tag zu setzen und das Etikett dann mit einem Rand zu versehen:
Stylen Sie dann das Etikett:
quelle
label { position: relative; overflow: hidden; width: 16px; height: 16px; border: 1px solid #0f0; }
und dannlabel > input[type=checkbox] { position: absolute; left: -999px; }
können Sie Ihr eigenes Kontrollkästchen individuell gestalten und das ursprüngliche Kontrollkästchen wird weiterhin aktiviert / deaktiviert, aber der Benutzer wird es nicht sehen. Sie sehen nur Ihr benutzerdefiniertes Kontrollkästchen.:hover
und:checked
zum Formatieren anderer Status Ihres benutzerdefinierten Kontrollkästchens verwenden.Hier ist meine Version, die FontAwesome als Kontrollkästchen verwendet. Ich denke, FontAwesome wird von fast jedem verwendet, daher kann man davon ausgehen, dass Sie es auch haben. Nicht in IE / Edge getestet und ich denke, niemand kümmert sich darum.
quelle
Für Firefox , Chrome und Safari passiert nichts.
Für IE der Rahmen außerhalb des Kontrollkästchens angewendet (nicht als Teil des Kontrollkästchens), und der "ausgefallene" Schattierungseffekt im Kontrollkästchen ist weg (wird als altmodisches Kontrollkästchen angezeigt).
Für Opera wendet der Rahmenstil den Rand tatsächlich auf das Kontrollkästchenelement an.
Opera behandelt auch andere Stile auf dem Kontrollkästchen besser als andere Browser: Farbe wird als Farbe des Häkchens angewendet , Hintergrundfarbe wird als Hintergrundfarbe innerhalb des Kontrollkästchens angewendet (IE wendet den Hintergrund so an, als ob sich das Kontrollkästchen in einem
<div>
mit Hintergrund befindet). .Fazit
Die einfachste Lösung besteht darin, das Kontrollkästchen in ein Feld zu verpacken,
<div>
wie es andere vorgeschlagen haben.Wenn Sie das Erscheinungsbild vollständig steuern möchten, müssen Sie sich für den erweiterten Bild- / Javascript-Ansatz entscheiden, der auch von anderen entwickelt wurde.
quelle
Das Stylen von Kontrollkästchen (und vielen anderen Eingabeelementen für dieses Material) ist mit reinem CSS nicht wirklich möglich, wenn Sie das visuelle Erscheinungsbild drastisch ändern möchten.
Am besten implementieren Sie etwas wie jqTransform , das Ihre Eingaben durch Bilder ersetzt und Javascript-Verhalten anwendet, um ein Kontrollkästchen (oder ein anderes Element) nachzuahmen.
quelle
Nein, Sie können das Kontrollkästchen selbst immer noch nicht formatieren, aber ich habe (endlich) herausgefunden, wie eine Illusion formatiert werden kann, während die Funktionalität des Klicken auf ein Kontrollkästchen beibehalten wird. Dies bedeutet, dass Sie es umschalten können, auch wenn der Cursor nicht perfekt stillsteht, ohne das Risiko einzugehen, Text auszuwählen oder Drag & Drop auszulösen!
Das Beispiel verwendet eine span-Schaltfläche sowie Text in einer Beschriftung. Sie erhalten jedoch eine Vorstellung davon, wie Sie das Kontrollkästchen unsichtbar machen und alles dahinter zeichnen können.
Diese Lösung passt wahrscheinlich auch zu Optionsfeldern.
Das Folgende funktioniert in IE9, FF30.0 und Chrome 40.0.2214.91 und ist nur ein einfaches Beispiel. Sie können es weiterhin in Kombination mit Hintergrundbildern und Pseudoelementen verwenden.
http://jsfiddle.net/o0xo13yL/1/
quelle
Hier ist eine einfache Möglichkeit (vor oder nach Pseudoelementen / Klassen zu verwenden):
quelle
quelle
Setze es in ein Div und füge dem Div einen Rand hinzu
quelle
quelle