我有从包含类别节点的xml读取并从中填充下拉列表的javascript代码。每次用户创建新产品列表时都会创建该类别节点。但是,这意味着读取xml时,该类别会填充相机,相机,相机,其他项目。我如何删除或有一个独特的选项?Javascript从下拉列表中删除重复项
function loadXMLcat()
{
var xmlhttp=false;
if (window.XMLHttpRequest)
{
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","auction.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML;
var category;
var str;
var i;
var j;
str=("<p>Category : <select onchange=\"reveal(this)\" name=category>");
var x=xmlDoc.getElementsByTagName("Product");
if(x.length>0)
{
for (i=0;i<x.length;i++)
{
category=xmlDoc.getElementsByTagName("Category");
str+="<option value=" + category[i].childNodes[0].nodeValue + ">" + category[i].childNodes[0].nodeValue + "</option>"
/**var arr = category;
var sorted_arr = arr.sort()
var results = [];
for (var i = 0; i < arr.length - 1; i++)
{
if (sorted_arr[i + 1] !== sorted_arr[i])
{
str+="<option value=" + arr[i] + ">" + arr[i] + "</option>"
str+="<option value=" + sorted_arr[i] + ">" + sorted_arr[i] + "</option>"
}
}**/
}
str+="<option id=\"others\" value=\"Other\">Other</option>";
}
else
str+="<option id=\"others\" value=\"Other\">Other</option>";
str+=("</select></p>");
document.getElementById('category').innerHTML=str;
}
第一把你的选项在Array&删除重复从这个数组:参见[从JavaScript数组删除重复(http://stackoverflow.com/questions/9229645/remove-duplicates-from-javascript-array ) –
它似乎只返回重复的[object element],它说arr.sort不是函数。 – JianYA
你可以发布你的代码的副本吗? –