@vedernikov

Как облегчить код jquery?

$('#ts5-right').click(function(){
           var cur=$('#ts5 > li:not(.text-hide)');
           var next=cur.next('li');
           if(!next.hasClass('text-hide')) next=$('#ts5 > li:first');
           cur.addClass('text-hide');           
           next.removeClass('text-hide');
        });
        $('#ts5-left').click(function(){
           var cur=$('#ts5 > li:not(.text-hide)');
           var prev=cur.prev('li');
           if(!prev.hasClass('text-hide')) prev=$('#ts5 > li:last');
           cur.addClass('text-hide');           
           prev.removeClass('text-hide');
        });


#ts может быть и #ts1, #ts2, ..., #tsN
Как можно облегчить код, чтобы не городить для каждого #ts* такое?
  • Вопрос задан
  • 2383 просмотра
Решения вопроса 1
Eugene_Sh
@Eugene_Sh
Через цикл прогонять, например:

var n = 5;

for (var i = 1; i <= n; i++) {
   $('#ts' + i + '-right').click(function() { ... });

   $('#ts' + i + '-left').click(function() { ... });
}

А еще можешь:

function addEventTs(n) {
   $('#ts' + n + '-right').click(function() { ... });

   $('#ts' + n + '-left').click(function() { ... });   
}

addEventTs(1);
addEventTs(5);

А можешь скомбинировать.
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 2
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Использовать в селекторе не id, а class
$('.tsN-right').click(function() {
    var cur = $(this)...// здесь написать выбор нужного элемента от кликабельного //
    var next = cur.next('li');
    if (!next.hasClass('text-hide'))
        next=$(this)...;
    cur.addClass('text-hide');           
    next.removeClass('text-hide');
});
Ответ написан
xmoonlight
@xmoonlight
https://sitecoder.blogspot.com
есть еще вариант, если нужны разные события (ветвления логики):
$('.tsN-right').each(function() {
       $(this).click(function(){
           var cur=$('#ts5 > li:not(.text-hide)');
           var next=cur.next('li');
           if(!next.hasClass('text-hide')) next=$('#ts5 > li:first');
           cur.addClass('text-hide');           
           next.removeClass('text-hide');
        });
  });
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
20 нояб. 2024, в 18:14
5000 руб./за проект
20 нояб. 2024, в 17:49
5000 руб./за проект
20 нояб. 2024, в 17:34
20000 руб./за проект