Как узнать последний индекс каждого () в jQuery? - PullRequest
38 голосов
/ 19 мая 2011

У меня есть что-то вроде этого ...

$( 'ul li' ).each( function( index ) {

  $( this ).append( ',' );

} );

Мне нужно знать, какой индекс будет для последнего элемента, поэтому я могу сделать так ...

if ( index !== lastIndex ) {

  $( this ).append( ',' );

} else {

  $( this ).append( ';' );

}

Есть идеи, ребята?

Ответы [ 6 ]

80 голосов
/ 19 мая 2011
var total = $('ul li').length;
$('ul li').each(function(index) {
    if (index === total - 1) {
        // this is the last one
    }
});
14 голосов
/ 19 мая 2011
var arr = $('.someClass');
arr.each(function(index, item) {
var is_last_item = (index == (arr.length - 1));
});
9 голосов
/ 19 мая 2011

Не забудьте кэшировать селектор $("ul li"), потому что это недешево.

Кэширование самой длины - это микрооптимизация, но это необязательно.

var lis = $("ul li"),
    len = lis.length;

lis.each(function(i) {
    if (i === len - 1) {
        $(this).append(";");
    } else {
        $(this).append(",");
    }
});
6 голосов
/ 19 мая 2011
    var length = $( 'ul li' ).length
    $( 'ul li' ).each( function( index ) {
        if(index !== (length -1 ))
          $( this ).append( ',' );
        else
          $( this ).append( ';' );

    } );
0 голосов
/ 24 мая 2018

с использованием jQuery .last ();

$("a").each(function(i){
  if( $("a").last().index() == i)
    alert("finish");
})

DEMO

0 голосов
/ 25 января 2018

Это очень старый вопрос, но есть более элегантный способ сделать это:

$('ul li').each(function() {
    if ($(this).is(':last-child')) {
        // Your code here
    }
})
...