▓▓▓▓▓▓ 大致介绍

    JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结

    先来建立一个数组

        var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN];

▓▓▓▓▓▓ 第一种

    思路:建立一个临时数组,用for循环去依次判断arr中的每个项在临时数组中是否有相同的值,如果没有则将这个值添加到临时数组,如果有相同的值则不添加,最后返回这个临时数组

    代码:

         Array.prototype.removeDuplicate = function(){
var n = [];
for(var i=0;i<this.length;i++){
if(n.indexOf(this[i]) == -1 ){
n.push(this[i]);
}
}
return n;
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的", NaN, NaN]

    注意:不会去掉重复的NaN值

▓▓▓▓▓▓ 第二种   

    思路:建立一个临时数组,用for循环利用indexOf()方法去依次判断arr中的每个项在arr中第一次出现的位置,如果这个项在arr中第一次出现的位置就是它的位置,表明在它之前没有相同的值则把它添加到临时数组中,如果这个项在arr中第一次出现的位置不是他的位置则表明在它之前有相同的值,则不把他添加到临时数组中;最后返回临时数组

    代码:

         Array.prototype.removeDuplicate = function(){
var n = [];
for(var i=0;i<this.length-1;i++){
if(this.indexOf(this[i]) == i){
n.push(this[i]);
}
}
return n;
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的"]

    注意:会把NaN值删除

▓▓▓▓▓▓ 第三种

    思路:建立一个临时对象,利用for循环检测这个临时对象有没有arr[i]这个属性,如果没有这个属性表明arr[i]在它之前没有和它重复的值。把临时对象的arr[i]属性设置为true,表明有这个属性并把这个项添加到临时数组中;最后返回临时数组

    代码:

         Array.prototype.removeDuplicate = function(){
var n = [],m = {};
for(var i=0;i<this.length;i++){
if(!m[this[i]]){
m[this[i]] = true;
n.push(this[i]);
}
}
return n;
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

▓▓▓▓▓▓ 第四种

    思路:先将这个数组排序,然后比较每个项和它后面的项的值是否相等,如果不相等则添加到临时数组中;最后返回临时数组

    代码:

         Array.prototype.removeDuplicate = function(){
var n = [];
this.sort();
for(var i=0;i<this.length;i++){
if(this[i] != this[i+1]){
n.push(this[i]);
}
}
return n;
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, 34, NaN, NaN, "我", "我的"]

    注意:不会去掉重复的NaN值

▓▓▓▓▓▓ 第五种

    思路:利用ES6的方法set方法去重,并用Array.from转换为数组

    set是一种新的数据结构,它可以接收一个数组或者是类数组对象,自动去重其中的重复项目,返回一个对象

    代码:

         Array.prototype.removeDuplicate = function(){
return (Array.from(new Set(this)));
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

最新文章

  1. SQL Server2008清除数据库日志
  2. 一个简单的Linq to TreeNode
  3. mongodb语法备份(转)
  4. 实现浏览器打开图片的url默认是下载
  5. C++11中对类(class)新增的特性
  6. HTML5中的canvas基本概念及绘图
  7. WEB urllib2 module note
  8. uTenux&mdash;&mdash;软件底层驱动组织结构介绍
  9. T-SQL 函数概述
  10. JavaScript创建类的方式
  11. MapReduce调度与执行原理之任务调度(续)
  12. 阿里笔试js题
  13. 一步一步学习Vue(十三)
  14. Android 实现串口的移植
  15. (NO.00003)iOS游戏简单的机器人投射游戏成形记(十三)
  16. 网络协议 4 - 交换机与 VLAN:办公室太复杂,我要回学校
  17. xterm配置
  18. centos 7 安装vscode
  19. JVM内存模型你只要看这一篇就够了
  20. dedecms (织梦)漏洞&amp;exp整理

热门文章

  1. 使用 Nodejs 搭建简单的Web服务器
  2. .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类
  3. Python高手之路【三】python基础之函数
  4. Linux scp 设置nohup后台运行
  5. Dreamweaver 扩展开发:C-level extensibility and the JavaScript interpreter
  6. AspNetPager分页控件样式的使用
  7. Android种使用Notification实现通知管理以及自定义通知栏(Notification示例四)
  8. ELK分析IIS日志
  9. nuget常用命令
  10. 我的MYSQL学习心得(三) 查看字段长度