Odpowiedzi:
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>");
?
.length
over, .size()
aby uniknąć narzutu wywołania funkcji. api.jquery.com/size
.length
to nie jest funkcja.
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.
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
Myślę, że to powinno wystarczyć:
var ct = $('#mylist').children().size();
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();
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>
$("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>