js 数组操作

js秘密花园:

http://bonsaiden.github.io/JavaScript-Garden/zh/

 

1、slice() 方法可从已有的数组中返回选定的元素,不改变原数组;

   splice()删除数组中的一段元素,,修改原数组;

    arr.spllice(要更改的起始位置包括在内,更改的数量,对应的更改的结果1,结果2,结果3,结果4,……),如果不设置更改的结果,则代表从起始位置开始,删除输入的元素的数量

2、依次添加,从第一个开始

push(向后添加的结果1,2,3,……)   ---------------pop()后删除一个数据

unshift(向前添加的结果1,2,3,……)-----------shift()前删除一个数据

join(参数),参数连接数组,不设置就默认为, ,就是转换成字符串

contact(),将两个数组连接起来 a.contact(b)

返回为新的连接数组,如果采用+,则是将数组先转换成字符串再拼接起来

a.reverse(),返回翻转的数组,并且修改原有数组

a.slice(头,尾) 包头不包尾,截取数组,返回截取的数组

a.indexOf(查找的参数),返回参数的位置第一个,没有找到就是返回-1

includes()也可以判断是否包含该元素,返回值是Boolean类型

字符串的split(参数)方法,可以把字符串按字符中的指定参数分割成多个字符串数组并返回

a.fill(0) 将数组中的所有元素设置为0

3、数组去重:

1.遍历数组法

它是最简单的数组去重方法(indexOf方法)

实现思路:新建一个数组,遍历去要重的数组,当值不在新数组的时候(indexOf为-1)就加入该新数组中;

4.优化遍历数组法(推荐)

实现思路:双层循环,外循环表示从0到arr.length,内循环表示从i+1到arr.length

将没重复的右边值放入新数组。(检测到有重复值时终止当前循环同时进入外层循环的下一轮判断)

function unique4(arr){
  var hash=[];
  for (var i = 0; i < arr.length; i++) {
    for (var j = i+1; j < arr.length; j++) {
      if(arr[i]===arr[j]){
        ++i;
      }
    }
      hash.push(arr[i]);
  }
  return hash;
}

5.ES6实现

基本思路:ES6提供了新的数据结构Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。

Set函数可以接受一个数组(或类似数组的对象)作为参数,用来初始化。

function unique5(arr){
  var x = new Set(arr);
 return [...x];
}

  

 

 

 

 

 

posted @ 2019-09-06 10:40  潇潇-lucky  阅读(266)  评论(0编辑  收藏  举报