我有一个ul列表,其中动态显示一个文件中的几个li。其中一些似乎有相同的标签,所以我想删除它们,只留下其中的一个:
我有这个:
<ul id="dealers-ul" data-next="#branches-ul">
<li class="select-option"><input type="radio" name="choice" id="344410" value="Barcelona Premium"><label for=" 344410 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343594" value="Barcelona Premium"><label for=" 343594 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343584" value="Barcelona Premium"><label for=" 343584 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="344444" value="Barcelona Premium"><label for=" 344444 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343882" value="Ibericar Cadí"><label for=" 343882 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343640" value="Ibericar Cadí"><label for=" 343640 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343856" value="Motor Munich"><label for=" 343856 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343831" value="Motor Munich"><label for=" 343831 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344363" value="Motor Munich"><label for=" 344363 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343902" value="Motor Munich"><label for=" 343902 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344450" value="Nürburgring"><label for=" 344450 "> Nürburgring</label></li>
<li class="select-option"><input type="radio" name="choice" id="344421" value="Pruna Motor"><label for=" 344421 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343628" value="Pruna Motor"><label for=" 343628 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343647" value="Sitjas"><label for=" 343647 "> Sitjas</label></li>
<li class="select-option"><input type="radio" name="choice" id="343892" value="Tallcar"><label for=" 343892 "> Tallcar</label></li>
</ul>
我只想要一份巴塞罗那高级,一份伊比里卡·卡迪,一份慕尼黑赛车,一份普鲁纳……
发布于 2017-11-27 17:39:52
var listForRemove = [];
var listOfUniqe = [];
$('#dealers-ul li').each(function () {
var text = $(this).text().trim();
if (listOfUniqe.indexOf(text) === -1)
listOfUniqe.push(text);
else
listForRemove.push($(this));
});
$(listForRemove).each(function () { $(this).remove(); });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="dealers-ul" data-next="#branches-ul">
<li class="select-option"><input type="radio" name="choice" id="344410" value="Barcelona Premium"><label for=" 344410 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343594" value="Barcelona Premium"><label for=" 343594 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343584" value="Barcelona Premium"><label for=" 343584 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="344444" value="Barcelona Premium"><label for=" 344444 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343882" value="Ibericar Cadí"><label for=" 343882 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343640" value="Ibericar Cadí"><label for=" 343640 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343856" value="Motor Munich"><label for=" 343856 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343831" value="Motor Munich"><label for=" 343831 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344363" value="Motor Munich"><label for=" 344363 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343902" value="Motor Munich"><label for=" 343902 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344450" value="Nürburgring"><label for=" 344450 "> Nürburgring</label></li>
<li class="select-option"><input type="radio" name="choice" id="344421" value="Pruna Motor"><label for=" 344421 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343628" value="Pruna Motor"><label for=" 343628 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343647" value="Sitjas"><label for=" 343647 "> Sitjas</label></li>
<li class="select-option"><input type="radio" name="choice" id="343892" value="Tallcar"><label for=" 343892 "> Tallcar</label></li>
</ul>
这应该可以完成以下工作:)
发布于 2017-11-27 17:40:36
希望这对你有帮助
uniqueLi = {};
$("#dealers-ul li").each(function () {
var thisVal = $(this).text();
if ( !(thisVal in uniqueLi) ) {
uniqueLi[thisVal] = "";
} else {
$(this).remove();
}
})
console.log(uniqueLi);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<ul id="dealers-ul" data-next="#branches-ul">
<li class="select-option"><input type="radio" name="choice" id="344410" value="Barcelona Premium"><label for=" 344410 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343594" value="Barcelona Premium"><label for=" 343594 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343584" value="Barcelona Premium"><label for=" 343584 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="344444" value="Barcelona Premium"><label for=" 344444 "> Barcelona Premium</label></li>
<li class="select-option"><input type="radio" name="choice" id="343882" value="Ibericar Cadí"><label for=" 343882 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343640" value="Ibericar Cadí"><label for=" 343640 "> Ibericar Cadí</label></li>
<li class="select-option"><input type="radio" name="choice" id="343856" value="Motor Munich"><label for=" 343856 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343831" value="Motor Munich"><label for=" 343831 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344363" value="Motor Munich"><label for=" 344363 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="343902" value="Motor Munich"><label for=" 343902 "> Motor Munich</label></li>
<li class="select-option"><input type="radio" name="choice" id="344450" value="Nürburgring"><label for=" 344450 "> Nürburgring</label></li>
<li class="select-option"><input type="radio" name="choice" id="344421" value="Pruna Motor"><label for=" 344421 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343628" value="Pruna Motor"><label for=" 343628 "> Pruna Motor</label></li>
<li class="select-option"><input type="radio" name="choice" id="343647" value="Sitjas"><label for=" 343647 "> Sitjas</label></li>
<li class="select-option"><input type="radio" name="choice" id="343892" value="Tallcar"><label for=" 343892 "> Tallcar</label></li>
</ul>
发布于 2017-11-27 17:36:05
最好不要一开始就添加重复的项目。此代码将删除重复的项。
var liText = '',
liList = $('#dealers-ul li'),
listForRemove = [];
$(liList).each(function() {
var text = $(this).text();
if (liText.indexOf('|' + text + '|') == -1)
liText += '|' + text + '|';
else
listForRemove.push($(this));
});
$(listForRemove).each(function() {
$(this).remove();
});
<ul id="dealers-ul" data-next="#branches-ul">
<li class="select-option">
<input type="radio" name="choice" id="344410" value="Barcelona Premium">
<label for=" 344410 "> Barcelona Premium</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343594" value="Barcelona Premium">
<label for=" 343594 "> Barcelona Premium</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343584" value="Barcelona Premium">
<label for=" 343584 "> Barcelona Premium</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="344444" value="Barcelona Premium">
<label for=" 344444 "> Barcelona Premium</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343882" value="Ibericar Cadí">
<label for=" 343882 "> Ibericar Cadí</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343640" value="Ibericar Cadí">
<label for=" 343640 "> Ibericar Cadí</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343856" value="Motor Munich">
<label for=" 343856 "> Motor Munich</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343831" value="Motor Munich">
<label for=" 343831 "> Motor Munich</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="344363" value="Motor Munich">
<label for=" 344363 "> Motor Munich</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343902" value="Motor Munich">
<label for=" 343902 "> Motor Munich</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="344450" value="Nürburgring">
<label for=" 344450 "> Nürburgring</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="344421" value="Pruna Motor">
<label for=" 344421 "> Pruna Motor</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343628" value="Pruna Motor">
<label for=" 343628 "> Pruna Motor</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343647" value="Sitjas">
<label for=" 343647 "> Sitjas</label>
</li>
<li class="select-option">
<input type="radio" name="choice" id="343892" value="Tallcar">
<label for=" 343892 "> Tallcar</label>
</li>
</ul>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
https://stackoverflow.com/questions/47507625
复制相似问题