javaScript常见的五种数组去重(转载)

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

    先来建立一个数组

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

▓▓▓▓▓▓ 第一种

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

    代码:

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

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

▓▓▓▓▓▓ 第二种   

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

    代码:

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

    注意:会把NaN值删除

▓▓▓▓▓▓ 第三种

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

    代码:

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

▓▓▓▓▓▓ 第四种

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

    代码:

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

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

▓▓▓▓▓▓ 第五种

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

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

    代码:

1         Array.prototype.removeDuplicate = function(){
2             return (Array.from(new Set(this)));
3         }
4         var m = arr.removeDuplicate();
5         console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]
时间: 2024-10-18 10:28:49

javaScript常见的五种数组去重(转载)的相关文章

js 跨域问题常见的五种解决方式

一.什么是跨域? 要理解跨域问题,就先理解好概念.跨域问题是由于javascript语言安全限制中的同源策略造成的. 简单来说,同源策略是指一段脚本只能读取来自同一来源的窗口和文档的属性,这里的同一来源指的是主机名.协议和端口号的组合. URL 说明 是否允许通信 http://www.a.com/a.js http://www.a.com/b.js 同一域名下 允许 http://www.a.com/lab/a.js http://www.a.com/script/b.js 同一域名下不同文件

JS 数组常见操作汇总,数组去重、降维、排序、多数组合并实现思路整理

壹 ? 引 JavaScript开发中数组加工极为常见,其次在面试中被问及的概率也特别高,一直想整理一篇关于数组常见操作的文章,本文也算了却心愿了. 说在前面,文中的实现并非最佳,实现虽然有很多种,但我觉得大家至少应该掌握一种,这样在面试能解决大部分数组问题.在了解实现思路后,日常开发中结合实际场景优化实现,提升性能也是后期该考虑的. 本文主要围绕数组去重.数组排序.数组降维.数组合并.数组过滤.数组求差集,并集,交集,数组是否包含某项等知识点展开,附带部分知识拓展,在看实现代码前也建议大家先自

探究JavaScript中的五种事件处理程序

我们知道JavaScript与HTML之间的交互是通过事件实现的.事件最早是在IE3和Netscape Navigator 2中出现的,当时是作为分担服务器运算负载的一种手段. 通俗地理解,事件就是用户或浏览器自身执行的某种操作.而事件处理程序即为响应某个事件的函数.抽出主干,即事件处理程序为函数.  我们又把事件处理程序称为事件侦听器.  事件处理程序是以"on"开头的,因此对于事件on的时间处理程序即为onclick.时间处理程序在JavaScript中大致有五种,下面会根据这五种

几种数组去重的方法

<script type="text/javascript">window.onload=function(){ /*数组去重方法一*//*var arr=[1,1,2,545,5,15,156,1,5,15]; var arr1=[]; for(var i=0;i<arr.length;i++){ if(arr1.indexOf(arr[i])==-1){ arr1.push(arr[i]); }; }; alert(arr1); */ /*数组去重方法二*//*

javascript面试题-原型实现数组去重

今天朋友去面试被问到一个问题,原型实现数组去重,乍一听着实有点蒙,但细细想来有些灵感 数组去重并不难,定义一个空数组,遍历要去重的数组的每一项,利用flag作为判断空数组中是否有一样的元素的标识,flag为true说明没有一样的,就添加到空数组中 利用原型实现,其实也就是在数组的原型上添加一个方法,让要去重的数组调用该方法 Array.prototype.remArr=function () { var arr=[]; var len=this.length; for(var i=0;i<len

PHP读取文件内容的五种方式(转载)

php读取文件内容的五种方式 分享下php读取文件内容的五种方法:好吧,写完后发现文件全部没有关闭.实际应用当中,请注意关闭 fclose($fp); php读取文件内容: -----第一种方法-----fread()-------- 1 <?php 2 $file_path = "test.txt"; 3 if(file_exists($file_path)){ 4 $fp = fopen($file_path,"r"); 5 $str = fread($f

JavaScript 几种数组去重的方法

一.利用for嵌套for,然后splice去重 let arr=[5,5,5,12,12,-3,33,33,35,8]; for( let i=0; i<arr.length;i++){ for(let k=i+1;k<arr.length;k++){ if(arr[i]===arr[k]){ arr.splice(i,1); i--; } }} console.log(arr) 二.Set方法去重 let arr = [1,2,2,3,4,3,1,6,7,3,5,7]; let s1 = n

HttpRequest中常见的四种ContentType【转载】

本文转自:http://www.aikaiyuan.com/6324.html HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS.GET.HEAD.POST.PUT.DELETE.TRACE.CONNECT 这几种.其中 POST 一般用来向服务端提交数据,本文主要讨论 POST 提交数据的几种方式. 我们知道,HTTP 协议是以 ASCII 码传输,建立在 TCP/IP 协议之上的应用层规范.规范把 HTTP 请求分为三个部分:状态行.请求头.消息主体.类似于下面这样: <m

Javascript中的五种数据类型

Undefined 未定义.只有一个值undefined Null         只有一个值,null Boolean 在javascript中,只要逻辑表达式不返回undefined不返回null,就都是真的. if(3) true if(null) false if(undefined) false Number   String javascript中不存在char类型. 字符串定义可以用单引号,也可以用双引号. <html> <head> <script type=