您好,欢迎来到[编程问答]网站首页   源码下载   电子书籍   软件下载   专题
当前位置:首页 >> 编程问答 >> Web开发 >> (javascript)JS数组去重方法最优解

(javascript)JS数组去重方法最优解

来源:网络整理     时间:2016/6/1 11:28:27     关键词:js数组

关于网友提出的“(javascript)JS数组去重方法最优解”问题疑问,本网通过在网上对“(javascript)JS数组去重方法最优解”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:

问题:(javascript)JS数组去重方法最优解
描述:

问题:同标题 要求:考虑值类型


解决方案1:

利用对象字面量的key与value关联性,写起来比较简单,未测试性能,考虑到只遍历一次,速度应该很快。

function distinct(arr) {
    var obj = {},
        i = 0,
        len = 0;
    if (Array.isArray(arr) && arr.length > 0) {
        len = arr.length;
        for (i = 0; i < len; i += 1) {
            obj[arr[i]] = arr[i];
        }
        return Object.keys(obj);
    }
    return [];
}
解决方案2:

jQuery.unique( array ); 

用法见jQuery.unique()

解决方案3:

http://docs.closure-library.googlecode.com/git/closure_goog_array_array.js.source.html#line887

看看 closure 的去重代码吧。这个不错。

解决方案4:

function unique(array){
    var n = [];//临时数组
    for(var i = 0;i < array.length; i++){
        if(n.indexOf(array[i]) == -1) n.push(array[i]);
    }
    return n;
}
解决方案5:

最快的方法是用jQuery:

var arr = ["1","2","3","4","5","4","3"];
var uniqueArr = [];
$.each(arr, function(i, el){
    if($.inArray(el, uniqueArr) === -1) uniqueArr.push(el);
});

不用jQuery, 你可以先排序,然后遍历此Array, 比较前后两个元素的值.

var arr = [9, 9, 111, 2, 3, 4, 4, 5, 7];
var sortedArr = arr.sort(); 
var results = [];
for (var i = 0; i < arr.length - 1; i++) {
    if (sortedArr[i + 1] == sortedArr[i]) {
        results.push(sortedArr[i]);
    }
}

alert(results);

以上介绍了“(javascript)JS数组去重方法最优解”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/1445518.html

相关图片

相关文章