我有一个类似以下格式的代码。我不想两次显示内容。例如,文本'问题1'在第一个ul标签中被重复4次。我希望它使用javascript / jquery显示一次。感谢。
<h3>Year 2010</h3>
<ul>
<li><a href="2010/1/2">Issue 2</a></li>
<li><a href="2010/1/1">Issue 1</a></li>
<li><a href="2010/1/2">Issue 2</a></li>
<li><a href="2010/1/1">Issue 1</a></li>
<li><a href="2010/1/1">Issue 1</a></li>
<li><a href="2010/1/1">Issue 1</a></li>
</ul>
<h3>Year 2011</h3>
<ul>
<li><a href="2010/1/2">Issue 2</a></li>
<li><a href="2010/1/1">Issue 1</a></li>
<li><a href="2010/1/2">Issue 2</a></li>
<li><a href="2010/1/2">Issue 2</a></li>
</ul>
答案 0 :(得分:1)
尝试使用:
$('ul').each(function(){
var issues = [];
$(this).find('li a').each(function(){
var text = $(this).text();
if($.inArray(text, issues) > -1){
$(this).parent().remove();
}else{
issues.push(text);
}
});
});
它循环遍历每个ul
,然后循环遍历其中的每个li a
。它将每个ul
的{{1}}元素的文本存储在数组(a
)中。
对于每个issues
,它检查文本是否已经添加到数组中(即它是重复的)。如果有,则删除父li a
,如果没有,则将其添加到数组中。
答案 1 :(得分:0)
以下是使用slice
将 NodeList 转换为数组和forEach
进行循环的原生 JavaScript 解决方案直接在 NodeList 上使用forEach
似乎有一些问题),在节点上跟removeChild
类似于我们之前看到的那样。
Array.prototype.slice.call(document.getElementsByTagName('ul')) // <ul>s to Array
.forEach( // loop over them
function (ul) {
var text = {}; // record what we have seen
Array.prototype.slice.call(ul.childNodes) // <li>s to Array
.forEach( // loop over these
function (li) {
if (li.nodeType !== 1 || li.tagName !== 'LI')
return; // only care about <li>s
if (text[li.textContent])
ul.removeChild(li); // seen it, remove
text[li.textContent] = 1; // mark seen
}
);
}
);
当然,您可以使用for
或while
循环,这会更快一些,但需要您跟踪更多变量..
var ul, li, i, j, text;
ul = document.getElementsByTagName('ul');
for (i = 0; i < ul.length; ++i) { // loop over <ul>
text = {}; // reset seen for each <ul>
li = ul[i].childNodes;
for (j = 0; j < li.length; ++j) { // loop over <ul> children
if (li[j].nodeType === 1 && li[j].tagName === 'LI') { // only <li>
if (text[li[j].textContent]) ul[i].removeChild(li[j]); // remove seen
text[li[j].textContent] = 1; // mark seen
}
}
}