金沙棋牌官方平台

当前位置:金沙棋牌 > 金沙棋牌官方平台 > JavaScript移除数组内重复元素的方法,javascript删除

JavaScript移除数组内重复元素的方法,javascript删除

来源:http://www.logblo.com 作者:金沙棋牌 时间:2019-08-29 15:55

javascript删除数组重复元素的方法汇总

   本文实例讲述了javascript删除数组重复元素的方法。分享给大家供大家参考。具体分析如下:

  这里分享一个前端面试高频题,主要实现javascript删除数组重复元素。希望对初学者有所帮助

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

//数组去重的方法

Array.prototype.unique=function(){

//集中声明变量

var

oldArr=this,

newArr=[oldArr[0]],

len=oldArr.length,

i=1;

//过滤空数组

if(!len) return this;

//过滤重复元素

for(;i<len;i ){

newArr.indexOf(oldArr[i])<0 ? newArr.push(_this) : '';

}

//返回过滤后的数组没有影响原数组

return newArr;

}

var arr=['a','a','b','a','c','d'];

console.log(arr.unique());

//["a", "b", "c", "d", unique: function]

  虽然网上也有很多而且自己写的也不咋地,但是毕竟自己写的逻辑清楚以后还可以顺着逻辑扩展比如扩展到对象元素去重或者是可以同时操作多个数组等等这里再放上别人的写的几个方法可以综合比较下

  方法1:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

function oSort(arr)

{

var result ={};

var newArr=[];

for(var i=0;i

{

if(!result[arr[i]])

{

newArr.push(arr[i])

result[arr[i]]=1

}

}

return newArr

}

  方法2:

  遍历要删除的数组arr, 把元素分别放入另一个数组tmp中,在判断该元素在arr中不存在才允许放入tmp中

  用到两个函数:for ...in 和 indexOf()

  ?

1

2

3

4

5

6

7

8

9

10

11

var student = ['qiang','ming','tao','li','liang','you','qiang','tao'];

function unique(arr){

// 遍历arr,把元素分别放入tmp数组(不存在才放)

var tmp = new Array();

for(var i in arr){

//该元素在tmp内部不存在才允许追加

if(tmp.indexOf(arr[i])==-1){

}

}

return tmp;

}

  方法3:

  把目标数组arr的元素值和键的位置调换 自动就把重复的元素给删除掉了,调换后的样子:array('qiang'=>1,'ming'=>1,'tao'=>1)

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<script type="text/javascript">

var student = ['qiang','ming','tao','li','liang','you','qiang','tao'];

function unique(arr){

var tmp = new Array();

for(var m in arr){

tmp[arr[m]]=1;

}

//再把键和值的位置再次调换

var tmparr = new Array();

for(var n in tmp){

tmparr.push(n);

}

return tmparr;

}

</script>

  方法4

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

/**

* 去除数组重复元素

*/

function uniqueArray(data){

data = data || [];

var a = {};

for (var i=0; i<data.length; i ) {

var v = data[i];

if (typeof(a[v]) == 'undefined'){

a[v] = 1;

}

};

data.length=0;

for (var i in a){

data[data.length] = i;

}

return data;

}

  方法都差不多第三个方法想法还是蛮高明的~

  希望本文所述对大家的javascript程序设计有所帮助。

本文实例讲述了javascript删除数组重复元素的方法。分享给大家供大家参考。具体分析如下: 这里分享...

javascript删除数组重复元素的方法汇总,javascript数组

本文实例讲述了javascript删除数组重复元素的方法。分享给大家供大家参考。具体分析如下:

这里分享一个前端面试高频题,主要实现javascript删除数组重复元素。希望对初学者有所帮助

//数组去重的方法
Array.prototype.unique=function(){
  //集中声明变量
  var 
   oldArr=this,
   newArr=[oldArr[0]],
   len=oldArr.length,
   i=1;
  //过滤空数组
  if(!len) return this;
  //过滤重复元素
  for(;i<len;i  ){
    newArr.indexOf(oldArr[i])<0 ? newArr.push(_this) : ''; 
  }
  //返回过滤后的数组没有影响原数组
  return newArr;
}
var arr=['a','a','b','a','c','d'];
console.log(arr.unique());
//["a", "b", "c", "d", unique: function]

虽然网上也有很多而且自己写的也不咋地,但是毕竟自己写的逻辑清楚以后还可以顺着逻辑扩展比如扩展到对象元素去重或者是可以同时操作多个数组等等这里再放上别人的写的几个方法可以综合比较下

方法1:

function oSort(arr)
{
  var result ={};
  var newArr=[];
  for(var i=0;i
  {
 if(!result[arr[i]])
 {
   newArr.push(arr[i])
   result[arr[i]]=1
 }
  }
  return newArr
}

方法2:

遍历要删除的数组arr, 把元素分别放入另一个数组tmp中,在判断该元素在arr中不存在才允许放入tmp中
用到两个函数:for ...in 和 indexOf()

var student = ['qiang','ming','tao','li','liang','you','qiang','tao'];
 function unique(arr){
   // 遍历arr,把元素分别放入tmp数组(不存在才放)
   var tmp = new Array();
   for(var i in arr){
  //该元素在tmp内部不存在才允许追加
  if(tmp.indexOf(arr[i])==-1){
  }
 }
  return tmp;
}

方法3:

金沙棋牌官方平台,把目标数组arr的元素值和键的位置调换 自动就把重复的元素给删除掉了,调换后的样子:array('qiang'=>1,'ming'=>1,'tao'=>1)

<script type="text/javascript">
  var student = ['qiang','ming','tao','li','liang','you','qiang','tao'];
  function unique(arr){
    var tmp = new Array();
    for(var m in arr){
      tmp[arr[m]]=1;
    }
    //再把键和值的位置再次调换
    var tmparr = new Array();
    for(var n in tmp){
     tmparr.push(n);
    }
   return tmparr;
 }
</script>

方法4

/**
* 去除数组重复元素
*/
function uniqueArray(data){ 
  data = data || []; 
  var a = {}; 
  for (var i=0; i<data.length; i  ) { 
    var v = data[i]; 
    if (typeof(a[v]) == 'undefined'){ 
      a[v] = 1; 
    } 
  }; 
  data.length=0; 
  for (var i in a){ 
    data[data.length] = i; 
  } 
  return data; 
} 

方法都差不多第三个方法想法还是蛮高明的~

希望本文所述对大家的javascript程序设计有所帮助。

本文实例讲述了javascript删除数组重复元素的方法。分享给大家供大家参考。具体分析如...

JavaScript移除数组内重复元素的方法,javascript移除

本文实例讲述了JavaScript移除数组内重复元素的方法。分享给大家供大家参考。具体分析如下:

这段JS代码用于从数组中移除重复的元素,比如: ['apple', 'orange', 'peach', 'apple', 'strawberry', 'orange'] 去重后返回:s ['apple', 'orange', 'peach', 'strawberry']
复制代码 代码如下:function removeDuplicates(arr) {
    var temp = {};
    for (var i = 0; i < arr.length; i )
        temp[arr[i]] = true;
    var r = [];
    for (var k in temp)
        r.push(k);
    return r;
}
//Usage
var fruits = ['apple', 'orange', 'peach', 'apple', 'strawberry', 'orange'];
var uniquefruits = removeDuplicates(fruits);
//print uniquefruits ['apple', 'orange', 'peach', 'strawberry'];

下面的代码可以在浏览器中验证
复制代码 代码如下:Remove duplicate elements from an array.  <br>
<pre>     var fruits = ['apple', 'orange', 'peach', 'apple', 'strawberry', 'orange'];
</pre>
Note 'orange' is duplicate in fruits array. Click to remove duplicate elements from fruits array:<br>
<button onclick="check()">Remove Duplicate</button>
<script>
function removeDuplicates(arr) {
    var temp = {};
    for (var i = 0; i < arr.length; i )
        temp[arr[i]] = true;
    var r = [];
    for (var k in temp)
        r.push(k);
    return r;
}
function check() {
    var fruits = ['apple', 'orange', 'peach', 'apple', 'strawberry', 'orange'];
    var uniquefruits = removeDuplicates(fruits);
    alert(uniquefruits);
}
</script>

希望本文所述对大家的javascript程序设计有所帮助。

本文实例讲述了JavaScript移除数组内重复元素的方法。分享给大家供大家参考。具体分析如...

本文由金沙棋牌发布于金沙棋牌官方平台,转载请注明出处:JavaScript移除数组内重复元素的方法,javascript删除

关键词: