{ let array = ['aa',12,'aa',16,12,'ab']; function dedupe(array) { //es6 return [...new Set(array)] } dedupe(array); //等价于 Array.from(new Set(array)); }
{ let array = ['aa',12,'aa',16,12,'ab']; array.filter((item, index) => { return array.indexOf(item) == index; }); }
reverse()es6
{ let arr = ['a','b','c',1,3]; arr.reverse(); }
返回结果: [3, 1, "c", "b", "a"]数组
concat() 方法用于链接两个或多个数组,该方法不会改变现有的数组,而仅仅会返回被链接数组的一个副本
arr0.concat(arr1, arr2, arr3, ......, arrx);
例:ui
{ [1,2,3].concat(4,5) [1,2,3].concat([4,5],6) [1,2,3].concat([4,5],[6,7,8]) }
返回结果:
[1, 2, 3, 4, 5]
[1, 2, 3, 4, 5, 6]
[1, 2, 3, 4, 5, 6, 7, 8]code
es6 扩展运算符,最简单的写法,一万个推荐!!!排序
{ let arr = ['1s','2s','3s',4]; let arr2 = ['1a','2a']; console.log([...arr,...arr2]); }
返回结果:["1s", "2s", "3s", 4, "1a", "2a"]递归
push()把一个或多个参数附加在数组末尾,返回数组长度。改变数组自身。字符串
{ let a = ['a','b','v']; let b = ['c','d','g']; a.push(...b) console.log(a) }
返回结果:["a", "b", "v", "c", "d", "g"]
注意: push()方法返回的是数组长度,如上示例,console.log(a.push(...b))返回值为6string
unshift()把一个或多个参数插入到数组头部,返回数组长度。改变数组自身。it
{ let arr = [1, 2, 3]; let count = arr.unshift(4, 5); console.log(count); console.log(arr); }
返回结果:
5
[4, 5, 1, 2, 3]io
join()方法,Array.join(标识符)
{ ['as2',12,'ss'].join('/'); }
返回结果:"as2/12/ss"
split()方法,string.split(标识符)
{ "as2/12/ss".split('/') }
返回结果:["as2", "12", "ss"]
arrayObject.splice(index,howmany,item1,.....,itemX)
参数描述:
index:必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
howmany:必需。要删除的项目数量。若是设置为 0,则不会删除项目。
item1, ..., itemX 可选。向数组添加的新项目。
返回值:
类型描述:Array 包含被删除项目的新数组,若是有的话。
说明:splice() 方法可删除从 index 处开始的零个或多个元素,而且用参数列表中声明的一个或多个值来替换那些被删除的元素。
若是从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。
示例:在 aa 和 bb 之间插入 aabb
{ let str = ['aa','bb',123,'sd13cx','jj',45]; str.splice(1,0,'aabb'); console.log(str) }
返回结果:["aa", "aabb", "bb", 123, "sd13cx", "jj", 45]
在 aa 和 bb 之间批量插入 ab、aabb、aaabbb
{
let str = ['aa','bb',123,'sd13cx','jj',45]; str.splice(1,0,'ab','aabb','aaabbb'); console.log(str);
}
返回结果:["aa", "ab", "aabb", "aaabbb", "bb", 123, "sd13cx", "jj", 45]
es6方法,使用‘...’扩展运算符
{ let str = ['aa','bb',123,'sd13cx','jj',45]; let arr = ['ab','aabb','aaabbb']; //巧用es6 "..." str.splice(1,0,...arr); console.log(str); }
示例:把 123 替换为 ccdd
{ let str = ['aa','bb',123,'sd13cx','jj',45]; str.splice(2,1,'ccdd'); console.log(str) }
返回结果:["aa", "bb", "ccdd", "sd13cx", "jj", 45]
把 123 替换为 123四、12345
{ let str = ['aa','bb',123,'sd13cx','jj',45]; str.splice(2,1,1234,12345); console.log(str); }
返回结果:["aa", "bb", 1234, 12345, "sd13cx", "jj", 45]
示例:把 123 删除
{ let str = ['aa','bb',123,'sd13cx','jj',45]; str.splice(2,1); console.log(str) }
{ let arr = ['aaa',111,222]; delete arr[1] console.log(arr,arr.length) //delete 只删除值,不删除引用空间 }
返回结果:["aaa", empty, 222] 3
{ let array = [1,4,-8,-3,6,12,9,8]; let bubbleSort = function(arr){ for(let i = 0;i < arr.length-1;i++){ for(let j = 0;j < arr.length-i-1;j++){ if(arr[j] < arr[j+1]){ let temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } return arr; } bubbleSort(array); }
(1)比较相邻的元素。若是第一个比第二个大,就交换他们两个位置。
(2)对每一对相邻元素做一样的工做,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
(3)针对全部的元素重复以上的步骤,除了最后一个。
(4)持续每次对愈来愈少的元素重复上面的步骤,直到没有任何一对数字须要比较。
{ //递归思想,两边快速的排序,冒泡排序的改进 let array = [1,4,-8,-3,6,12,9,8]; let quickSort = function(arr){ if(arr.length <= 1){ return arr; } let index = Math.floor(arr.length/2); let temp = arr.splice(index,1); let left = [],right = []; for(let item of arr){ if(item < temp){ left.push(item); }else{ right.push(item); } } return quickSort(left).concat(temp,quickSort(right)); } quickSort(array); }
Math.floor(x)方法是向下取整,返回小于或等于x的最接近的整数。
splice(index,num,item)方法是向数组中添加项目,或是从数组中删除项目,并返回被删除的项目。
index是整数,被操做项目所在的位置(必须)
num是整数,要删除的项目的数量,若是为0,表示不删除(必须)
item是向数组中添加的新项目,能够是多个(可选)
push()方法是向数组末尾添加一个或多个新项目并返回新数组的长度
concat()方法链接两个或多个数组,不会改变原有数组,返回一个新数组