jQuery: policzyć liczbę elementów listy?

134

Mam listę, która jest generowana z jakiegoś kodu po stronie serwera, zanim dodam do niej dodatkowe rzeczy za pomocą jQuery, muszę dowiedzieć się, ile elementów już się w niej znajduje.

<ul id="mylist">
    <li>Element 1</li>
    <li>Element 2</li>
</ul>
Tomek
źródło

Odpowiedzi:

225

Próbować:

$("#mylist li").length

Po prostu ciekawy: dlaczego musisz znać rozmiar? Nie możesz po prostu użyć:

$("#mylist").append("<li>New list item</li>");

?

cletus
źródło
3
Używam dołączania, aby dodać nowe, ale mam ograniczenie liczby pozycji, które mogą znajdować się na liście, w tym stanie użytkownik może nadal dodać maksymalnie 4 pozycje, ale 2 mogły nadejść od poprzedniego stanu. :)
Tom
35
Zauważ, że dokumentacja jQyery zaleca użycie .lengthover, .size()aby uniknąć narzutu wywołania funkcji. api.jquery.com/size
Joe,
4
size () został uznany za przestarzały w jquery 1.8 i teraz mówi o używaniu length () .
ponury.pingwin
8
@ gloomy.penguin Zauważ, że .lengthto nie jest funkcja.
heksacyjanid
Potrzebuję liczby <li>, aby ponownie obliczyć szerokość elementu w locie.
Hristo
51
var listItems = $("#myList").children();

var count = listItems.length;

Oczywiście możesz to skondensować

var count = $("#myList").children().length;

Aby uzyskać dalszą pomoc dotyczącą jQuery, http://docs.jquery.com/Main_Page jest dobrym miejscem do rozpoczęcia.

Nick Allen
źródło
5
na wszelki wypadek wykonaj $ ("# myList"). children ("li"). length; Jeśli kiedykolwiek z jakiegokolwiek powodu dodasz inne pozycje do listy, nie zapomnisz o tej małej linijce kodu.
SgtPooki
10

Ten sam wynik daje wywołanie metody .size () lub właściwości .length, ale właściwość .length jest preferowana, ponieważ nie ma narzutu związanego z wywołaniem funkcji. Więc najlepszy sposób:

$("#mylist li").length
Alex Nguyen
źródło
4

Myślę, że to powinno wystarczyć:

var ct = $('#mylist').children().size(); 
Andrew Barrett
źródło
4

i oczywiście:

var count = $("#myList").children().length;

można skrócić do: (usuwając „zmienną”, która nie jest konieczna do ustawienia zmiennej)

count = $("#myList").children().length;

jednak jest to czystsze:

count = $("#mylist li").size();
ROARSTAR
źródło
2
Czy ta metoda nie liczy również tagów li w elementach podrzędnych ul górnego ul?
atripes
2
Powiedzenie „„ zmienna ”nie jest konieczne do ustawienia zmiennej” jest zbytnim uproszczeniem. Jeśli nie użyjesz „var”, wszystkie twoje zmienne staną się globalne. Zobacz stackoverflow.com/questions/1470488/…
Rafael Almeida
3

próbować

$("#mylist").children().length
Nui_CpE
źródło
1

Policz liczbę elementów listy

alert($("#mylist > li").length);
M.Ganji
źródło
1

Inne podejście do liczenia liczby elementów listy:

var num = $("#mylist").find("li").length;
console.log(num);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="mylist">
  <li>Element 1</li>
  <li>Element 2</li>
  <li>Element 3</li>
  <li>Element 4</li>
  <li>Element 5</li>
</ul>

Penny Liu
źródło
0

$("button").click(function(){
    alert($("li").length);
 });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.2.3/jquery.min.js"></script>
<!DOCTYPE html>
<html>
<head>
<script src="//code.jquery.com/jquery-1.11.1.min.js"></script>
  <meta charset="utf-8">
  <title>Count the number of specific elements</title>
</head>
<body>
<ul>
  <li>List - 1</li>
  <li>List - 2</li>
  <li>List - 3</li>
</ul>
  <button>Display the number of li elements</button>
</body>
</html>

Bashirpour
źródło