Почему это происходит только в элементе div 1?
Код:
Код: Выделить всё
//hover effects
$(".respuesta1,.respuesta2,.respuesta3,.respuesta4").hover(
function () {
$(this).addClass("respuestahover");
},
function () {
$(this).removeClass("respuestahover");
});
//on click function for div1
$(".respuesta1").on("click", function () {
//if it hasnt been clicked, toogle class and change var to true
if (prendido1 == false) {
$(this).toggleClass("respuesta1b");
prendido1 = true;
//if any of the other divs are clicked by the time you are clicking unclicked 1, turn them off
if (prendido2 == true) {
$(".respuesta2").toggleClass("respuesta2b");
prendido2 = false;
}
if (prendido3 == true) {
$(".respuesta3").toggleClass("respuesta3b");
prendido3 = false;
}
if (prendido4 == true) {
$(".respuesta4").toggleClass("respuesta4b");
prendido4 = false;
}
//if is already clicked, turn off and change var to false
} else {
$(this).toggleClass("respuesta1b");
prendido1 = false;
}
});
Есть идеи?
РЕДАКТИРОВАТЬ
Я пытался очистить код, чтобы создать jsFiddle, и думаю, у меня получилось:
http://jsfiddle.net/bqySN/2/
Я просто оставлю код там, если кому-то интересно, имейте в виду, что код не доработан и требует большего обобщения.
РЕДАКТИРОВАТЬ 2
После некоторого тестирования я действительно обнаружил проблему:
если я изменю порядок CSS говорит, что приложение сходит с ума:
Это правильно, сначала с наведением курсора
Код: Выделить всё
.respuestahover{
background-color:#f00;
opacity:0.2;
}
.respuestab{
background-color:#f00;
opacity:0.5;
}
Код: Выделить всё
.respuestab{
background-color:#f00;
opacity:0.5;
}
.respuestahover{
background-color:#f00;
opacity:0.2;
}
Подробнее здесь: https://stackoverflow.com/questions/181 ... r-on-click
Мобильная версия