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]; }