在Javascript中,如何去除指定数组中的重复元素?
我打开firebug的console,花了30秒想,30秒写,结果如下:(x为目标数组,y是去除重复元素后的结果)
(责任编辑:admin)var x=[1,1,3,4,5,3]; var y=[]; var tArray=function(i,arr){ var yap=false; for(var j=0;j<arr.length;j++){ if(arr[j]==i){yap=true;break;}; } if(!yap) arr.push(i); }; for(var t=0;t<x.length;t++){ tArray(x[t],y); } alert(y.length); alert(y.toString()); 答案不是唯一的,而且没有标准答案,所以上面的代码是对的也是错的。如果数组是一个复杂对象数组呢?如果数组中包含多个空对象{}呢?要知道js里面有很多特殊甚至是bug的现象,alert({}=={})看看怎么回事... 注:如果谁有标准答案欢迎评论里面发下让大家学习学习。 出题者本身就不会考虑到这些问题。 不要去学习做题,在实际工作中遇到问题时高效解决问题的能力才是真正有价值的。 需要注意的地方补充: 有个问题应该注意下 arr[j]==i 您这里貌似 是指当数组元素 为number类型时的相等性判断... 但是往往我们可能要对不同类型做 相等性判断... 这个是实际应用时应该考虑的问题 1!=new Number(1)的情况 null==undefined 的情况 0=="0" 的情况 等等 所以 显然 简单的== 和===都是不合适的. 应该独立实现一个 equals 方法 做相等性判断... 要根据需求 设置规则 我举的例子正是针对number类型的数组的,目的是对“面试啥做题”表达一种态度。实际应用中应该根据实际需求去考虑。除非实际工作中要求或者我是个js学术研究者,否则我是不会独立去实现一个equals方法的。国外的开发员往往遵循一个信条:“Do The Simplest Thing That Could Possibly Work”,意思大概即“不要过度设计,适用至上”,我这几年的工作经验也常常印证着这个道理。不知道你怎么看。 |