【发布时间】:2010-10-10 23:54:10
【问题描述】:
我有一个从一些服务器端代码生成的列表,在使用 jQuery 向其中添加额外内容之前,我需要弄清楚其中已有多少项。
<ul id="mylist">
<li>Element 1</li>
<li>Element 2</li>
</ul>
【问题讨论】:
我有一个从一些服务器端代码生成的列表,在使用 jQuery 向其中添加额外内容之前,我需要弄清楚其中已有多少项。
<ul id="mylist">
<li>Element 1</li>
<li>Element 2</li>
</ul>
【问题讨论】:
试试:
$("#mylist li").length
只是好奇:为什么需要知道尺寸?你不能只使用:
$("#mylist").append("<li>New list item</li>");
?
【讨论】:
.length 而不是 .size() 以避免函数调用的开销。 api.jquery.com/size
.length 不是函数。
var listItems = $("#myList").children();
var count = listItems.length;
当然你可以把它压缩成
var count = $("#myList").children().length;
如需更多关于 jQuery 的帮助,http://docs.jquery.com/Main_Page 是一个不错的起点。
【讨论】:
调用 .size() 方法或 .length 属性时会得到相同的结果,但首选 .length 属性,因为它没有函数调用的开销。 所以最好的方法:
$("#mylist li").length
【讨论】:
我认为应该这样做:
var ct = $('#mylist').children().size();
【讨论】:
当然还有以下:
var count = $("#myList").children().length;
可以浓缩为:(通过删除不需要设置变量的'var')
count = $("#myList").children().length;
不过这样更干净:
count = $("#mylist li").size();
【讨论】:
试试
$("#mylist").children().length
【讨论】:
计算列表元素个数
alert($("#mylist > li").length);
【讨论】:
另一种计算列表元素数量的方法:
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>
【讨论】: