Domanda

Ho questa icona OK CSS3 creata con CSS. http://jsfiddle.net/5c9GN/

JS:

$('.ok').mouseenter(function(){
    $(this).parent().find('.ok:after, .ok:before').css('background','#ccc');
    $(this).css('background','#33CC33');
});
$('.ok').mouseleave(function(){
    $(this).parent().find('.ok:after, .ok:before').css('background','#ccc');
    $(this).css('background','#ccc');
});
.

CSS:

.ok{height:40px; width:40px; display:block; position:relative; margin-left: auto; margin-right: auto;} 

.ok:after, .ok:before{content:''; height:32px; width:10px; display:block; background:   #ccc; position:absolute; top:6px; left:18px; transform:rotate(45deg);-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-o-transform:rotate(45deg);-ms-transform:rotate(45deg);}

.ok:before{height:16px; transform:rotate(-45deg);-webkit-transform:rotate(-45deg);-moz-transform:rotate(-45deg);-o-transform:rotate(-45deg);-ms-transform:rotate(-45deg); top:18px; left:6px;}
.

E sto avendo un piccolo problema mentre cerchi di cambiare il colore dell'icona.Cambia sempre il colore di sfondo non l'icona. Qualcuno può aiutarmi? Grazie

È stato utile?

Soluzione

Utilizzo solo CSS:

Demo

.ok:hover:after, .ok:hover:before {
    background: #33CC33;
}
.

Altri suggerimenti

Aggiungi questo css

.ok.mouseover:after, .ok.mouseover:before{
     background:    #33CC33;
}
.

e aggiorna il tuo codice JS a questo

$('.ok').mouseenter(function(){
    $(this).addClass('mouseover');
});
$('.ok').mouseleave(function(){
    $(this).removeClass('mouseover');
});
.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top