我有一个列表,我只想从中删除所有子节点。使用jquery的最有效方法是什么?这就是我所拥有的:
<ul id='foo'>
<li>a</li>
<li>b</li>
</ul>
var thelist = document.getElementById("foo");
while (thelist.hasChildNodes()){
thelist.removeChild(thelist.lastChild);
}
有一种捷径而不是一次删除每个项目吗?
-----------编辑----------------
每个列表元素都有一些附加的数据,以及一个单击处理程序,如下所示:
$('#foo').delegate('li', 'click', function() {
alert('hi!');
});
// adds element to the list at runtime
function addListElement() {
var element = $('<li>hi</hi>');
element.data('grade', new Grade());
}
最终我也可能会为每个列表项添加按钮-因此,看来方法为empty(),以确保没有内存泄漏?