Почему addClass и removeClass ломают мой jQuery?
$('.selected').removeClass('selected');
$(this).addClass('selected');
Перед добавлением 2 строк кода выше вся функция работала. Теперь, когда я нажимаю, работают только эти две строки, а остальная часть моего кода - нет. Если я уберу эти две строки, код снова заработает. Что может сделать удаление класса и добавление класса, чтобы разрушить остальную часть этой функции? Что я здесь не так делаю?
$(document).ready(function(){
var subject;
$('.subject').mouseenter(function(){
if ( $(this).hasClass(subject) ) {
return 0;
}
else {
$(this).find('.info, img').fadeTo('fast', 1);
}
});
$('.subject').mouseleave(function(){
if ( $(this).hasClass(subject) ) {
return 0;
}
else {
$(this).find('.info').fadeTo('fast', 0);
$(this).find('img').fadeTo('fast', 0.8);
}
});
// BELOW IS WHERE THE PROBLEM IS
$('[class$=-link]').click(function(){
$('.selected').removeClass('selected'); // Why do these lines break the
$(this).addClass('selected'); // rest of this function?
$('.' + subject).find('.info').fadeTo('fast', 0);
$('.' + subject).find('img').fadeTo('fast', 0.8);
subject = $(this).attr('class').replace("-link","");
$('.'+ subject ).find('.info, img').fadeTo('fast', 1);
});
});
1 ответ
Решение
Насколько я могу сказать, вы хотите что-то вроде этого (избегая необходимости менять HTML):
$('[class$=-link]').click(function(){
$('.selected').removeClass('selected');
$('.' + subject).find('.info').fadeTo('fast', 0).end().find('img').fadeTo('fast', 0.8);
subject = $(this).attr('class').replace("-link","");//execute this line while "selected" class is not present
$('.'+ subject).find('.info, img').fadeTo('fast', 1);
$(this).addClass('selected');//add after everything else is complete
});