Próbuję utworzyć niestandardowe pola wyboru przy użyciu CSS3, który działa doskonale w przeglądarce Chrome. W przeglądarce Firefox ... nie tak bardzo.Niestandardowe skrzynki wyboru nie działające w przeglądarce Firefox
Edit: wydaje się, że działa poprawnie na Firefox 37.
Poniższa odpowiedź jest nadal aktualna, ale kwestie związane z trybem od połowy 2013 roku zostały rozwiązane.
Wsparcie dla IE nie jest tutaj wymienione, ale poprawki/odpowiedzi dotyczące tego są mile widziane.
demo
HTML:
<input type="checkbox" id="first"/>
<label for="first">This is pretty awesome</label>
CSS:
input[type=checkbox] {
appearance: none;
background: transparent;
position: relative;
}
input[type=checkbox]::after {
position: absolute;
top: 0;
left: 0;
content: '';
text-align: center;
background: #aaa;
display: block;
pointer-events: none;
opacity: 1;
color: black;
border: 3px solid black;
}
input[type=checkbox] + label {
line-height: 48px;
margin: 0 15px 0 15px;
}
input[type=checkbox]:hover::after {
content: '';
background: #32cd32;
opacity: .3;
}
input[type=checkbox]:checked::after {
content: '\2713';
background: #32cd32;
}
input[type=checkbox]:checked:hover::after {
opacity: 1;
}
input[type=checkbox],
input[type=checkbox]::after {
width: 48px;
height: 48px;
font-size: 46px;
line-height: 48px;
vertical-align: middle;
border-radius: 50%;
}
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
Uwaga: Usunąłem prefiksy dostawców i rzeczy jak użytkownik-wybierz dla zwięzłości. Pełny kod znajduje się w pisaku.
Co muszę zmienić, aby wyglądał tak samo w Firefoksie, jak w przeglądarce Chrome?
Pożądany:
Nie życzenia:
niemożliwe z czystym CSS. adres URL: http://stackoverflow.com/questions/2587669/css-after-pseudo-element-on-input-field –
inny link do Mozilli: http://forums.mozillazine.org/viewtopic.php?f=25&t= 291007 –
Przepraszam, poprawiłem zdjęcie. Tak więc tekst dodatkowy * pojawia się * w przeglądarce Firefox, ale nie pokazuje promienia obramowania ani cieniowania. Chciałbym nawet jakoś ukryć pole wyboru. Próbuję ukryć pole wyboru i utworzyć ':: after' a' :: before' etykiety. – FakeRainBrigand