// 无参构建
let arr = new Array(); //创建一个空数组 []
// 如果只传一个数值参数,则表示创建一个初始长度为指定数值的空数组
let arr = new Array(5); // 创建一个包含20项的数组 [empty × 5]
// 如果传入一个非数值的参数或者参数个数大于 1,则表示创建一个包含指定元素的数组。
let arr = new Array("lily","lucy","Tom"); // ['lily', 'lucy', 'Tom']
let arr = new Array( '23' ); // ["23"]
ES6 为数组新增创建方法的目的之一,是帮助开发者在使用 Array 构造器时避开 js 语言的一个怪异点。
Array.of()方法总会创建一个包含所有传入参数的数组,而不管参数的数量与类型。
let arr = Array.of(1, 2); // [ 1, 2 ]
let arr1 = Array.of(3);
console.log('Array.of',arr1.length); //1
console.log('Array.of',arr1[0]); //3
在 js 中将非数组对象转换为真正的数组是非常麻烦的。在 ES6 中,将可迭代对象或者类数组对象作为第一个参数传入,Array.from()就能返回一个数组。
function arga(...args) { //...args剩余参数数组,由传递给函数的实际参数提供
let arg = Array.from(args);
console.log(arg);
}
arga( 'arr1' , 26, 'from' ); // [ arr1 ,26, from ]
映射转化
如果你想实行进一步的数组转换,你可以向 Array.from()方法传递一个映射用的函数作为第二个参数。此函数会将数组对象的每一个值转换为目标形式,并将其存储在目标数组的对应位置上。
function arga(...args) {
return Array.from(args, value => value + 1);
}
let arr = arga( 'arr' , 26, 'pop' );
console.log(arr);//[ arr1 ,27, pop1 ]
该方法可以将数组里的元素,通过指定的分隔符,以字符串的形式连接起来。
返回值:返回一个新的字符串
//将数组用 - 符号连接起来
let arr = [1,2,3,4,5];
let str = arr.join('-');
console.log('join',str) // str = 1-2-3-4-5;
该方法是用过指定的分隔符,将字符串分割成数组。
返回值:返回一个新的数组
let str = 'wqz-ttj'
let arr = str.split('-');
console.log('split',arr);// arr=['wqz','ttj'];
let arr = [1,2,3,4,5];
arr.reverse()
console.log('reserse',arr); // [5, 4, 3, 2, 1]
let arr = [1,3,5,2,4,23,122,34];
// 没有参数:时按照首字符的先后排序
arr.sort()
console.log('没有参数',arr); //arr=[1,122,2,23,3,34,4,5];
// 有参数
arr.sort(function(a,b){
return a-b;//从小到大排序
return b-a;//从大到小排序
})
console.log('正序排列',arr); // [1, 2, 3, 4, 5, 23, 34, 122]
concat 方法会将参数拼接到该数组中;
如果是基本数据类型,那么直接添加进去;
如果是数组类型那么会将外层的 【】去掉,只将参数添加进去
如果是数组嵌套数组,那么只会扒掉一层 【】,将内层数组添加进去
let arr1 = [1,2,3];
let arr2 = [4,5,6];
let arr = arr1.concat(arr2);
console.log(arr); //arr = [1,2,3,4,5,6];
arr = arr1.concat({ name: '张三' })
console.log(arr); // arr = [1,2,3, { name: '张三' }]
arr = arr1.concat([ [ 7,8,9 ] ])
console.log(arr); // arr = [1,2,3, [7,8,9]]
arr1.push(arr2);
console.log(arr1); //arr1 = [1,2,3,[4,5,6]];
该方法可以从数组中截取指定的字段,返回出来
返回值:返回截取出来的字段,放到新的数组中,不改变原数组
从start下标开始截取,一直到end结束,不包括end
arr = [0,1,2,3,4,5,6,7];
let newArr = arr.slice(0,3)//newArr = [0,1,2];
console.log('slice',newArr);
从start下标开始截取,一直到最后
let arr = [0,1,2,3,4,5,6,7];
newArr = arr.slice(2)//newArr = [2,3,4,5,6,7];
console.log('slice',newArr);
全部截取
let arr = [0,1,2,3,4,5,6,7];
newArr = arr.slice()//newArr = [0,1,2,3,4,5,6,7];
console.log('slice',newArr);
删除或增加元素(任意在任何位置,直接改变原数组,返回的是被删除元素组成的新数组或者空数组)
从start下标开始,删除几个
let arr = [0,1,2,3,4,5,6,7]
arr.splice(1,2) //newArr = [1,2];
console.log('splice',arr); // [0, 3, 4, 5, 6, 7]
从start下标开始,删除几个,并在该位置添加item
let arr = [0,1,2,3,4,5,6,7]
arr.splice(1,2, 10, 20, 30) // newArr = [1,2];
console.log('splice',arr); // [0, 10, 20, 30, 3, 4, 5, 6, 7]
从start下标开始,删除0个,并在该位置添加item,start开始全部往后移动
let arr = [0,1,2,3,4,5,6,7]
arr.splice(2,0,10,20,30); //arr = [0,1,2,3,4,5,6,7]
console.log('splice',arr); // [0, 1, 10, 20, 30, 2, 3, 4, 5, 6, 7]
查找元素在数组中出现的位置
arr.indexOf (ele,fromIndex) 接收两个参数
第一个参数是查找的元素
第二个参数是从那个下标开始查找
找到返回元素下标 ; 未找到返回-1
let arr = [0,1,2,3,4,5,6,7]
// 从左向右开始筛查
if( arr.indexOf( 4 ) === -1 ) {
console.log('indexOf','元素不存在');
} else {
console.log('indexOf','元素存在');
}
// 从右向左开始筛查
if( arr.lastIndexOf( 4 ) === -1 ) {
console.log('lastIndexOf','元素不存在');
} else {
console.log('lastIndexOf','元素存在');
}
该方法等同于for循环,没有返回值,可以修改原数组
let arr.forEach(function(item,index,arr){
//里面的function是一个回调函数,
//item: 数组中的每一项;
//index:item 对应的下标索引值
//arr: 就是调用该方法的数组本身
})
映射,该方法使用和forEach大致相同,但是该方法有返回值,返回一个新数组,新数组的长度和原数组长度相等,可以修改原数组。
//里面的function是一个回调函数,
//item: 数组中的每一项;
//index:item 对应的下标索引值
//arr: 就是调用该方法的数组本身
let arr = [1,32,54,6,543];
let res = arr.map(function(item,index,arr){
return item*2;
})
console.log('map',res); // [2, 64, 108, 12, 1086]
filter方法: 有返回值, 过滤出符合条件的元素
let arr = [1, 3, 5, 2, 4, 6];
let res3 = arr.filter(function(item, index) {
return item % 2 === 0;
});
console.log('filter',res3); // [2, 4, 6]
过滤出布尔类型为true的项
let arr2 = [0, "", false, 1, 3, 4];
let res4 = arr2.filter(function(item, index) {
return item;
});
console.log('filter',res4); // [1,3,4]
判断数组中有没有符合条件的项(只要有,就返回true),如果一个都没有,才返回false
let arr3 = [
{ name: "zs", age: 18, done: "notYet" },
{ name: "ls", age: 20, done: true },
{ name: "ww", age: 22, done: true }
];
let res5 = arr3.some(function(item) {
return item.done;
});
console.log('some',res5); // true
判断数组中所有的项是否满足要求,如果全都满足,才返回true,否则返回false
let arr3 = [
{ name: "zs", age: 18, done: "notYet" },
{ name: "ls", age: 20, done: true },
{ name: "ww", age: 22, done: true }
];
let res6 = arr3.every(function(item) {
return item.done;
});
console.log('every',res6); // true
找到符合条件的项,并且返回第一项
let arr4 = [
{ id: 3, name: "ls", done: false },
{ id: 1, name: "zs", done: true },
{ id: 2, name: "ww", done: true }
];
var res7 = arr4.find(function(item) {
return item.done;
});
console.log('find',res7); // {id: 1, name: 'zs', done: true}
找到符合条件的项的下标,并且返回第一个
arr4 = [
{ id: 3, name: "ls", done: false },
{ id: 1, name: "zs", done: true },
{ id: 2, name: "ww", done: true }
];
var res8 = arr4.findIndex(function(item) {
return item.done;
});
console.log('findindex',res8); // 1
1.当reduce()方法的第二个值为空时,第一次循环方法中的第一个参数(prev)为数组的第一项值,第二个参数(cur)为数组的第二项值,反之,第一次循环方法中的第一个参数(prev)为reduce的第二个参数值,第二个参数(cur)为数值的第一项值。
2.reduce()方法的第一个参数,就是每次遍历都会执行的匿名函数,当前函数的返回值就会传给下一次执行函数的第一个值。也就是prev
1.求和计算
*第一次:pre–>1 next–>2 index–>1
pre+next=1+2=3
*第二次:pre–>3 next–>3 index–>2
pre+next=3+3=6
*第三次:pre–>6 next–>4 index–>3
pre+next=6+4=10
*第四次:pre–>10 next–>5 index–>4
let arr1 = [1, 2, 3, 4, 5];
var new1 = arr1.reduce(function (pre, next, index) {
console.log('reduce',pre,next),index;
return pre + next;
//pre+next=10+5=15
})
console.log('reduce total',new1); // 15
2.扁平化数组(拼接数组)
let arr2 = [[1,2,3],[4,5],[6,7]] ;
var new2 = arr2.reduce(function(pre,next,index){
return pre.concat(next); //前数组拼接后数组 .concat()
})
console.log('reduce',new2); // [1, 2, 3, 4, 5, 6, 7]
对象数组叠加计算
let arr3 = [
{ price: 10, count: 1 },
{ price: 15, count: 2 },
{ price: 10, count: 3 }
];
var new3 = arr3.reduce(function (pre, next, index) {
return pre + next.price * next.count;
}, 0) //在原数组第一项添加为0,不改变原数组,则可不操作第一项
console.log('reduce 对象数组叠加', new3); // 70
应用 : 计算数组中每个元素出现的次数
投票板
var names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];
var countedNames = names.reduce(function (allNames, name) {
// console.log(allNames, '| ' + name);
if (name in allNames) {
allNames[name]++;
} else {
allNames[name] = 1;
}
return allNames;
}, {});
console.log('reduce 投票版',countedNames); // {Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}
方法能使用特定值填充数组中的一个或多个元素
let arr = new Array(10)
// 填充数组
arr.fill('A') // ['A', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A']
// 替换数组元素:
arr.fill(0, 2, 4); // 从索引2到索引4(不包括4)之间的元素替换为0
console.log(array); // ['A', 'A', 0, 0, 'A', 'A', 'A', 'A', 'A', 'A']
// 扩展数组长度
const array = [1, 2, 3];
array.length = 5; // 扩展数组长度
array.fill(0); // 填充新增的元素为0
console.log(array); // [1, 2, 3, 0, 0]
是 JavaScript 中用于检查数组是否包含指定元素的方法。它会返回一个布尔值,表示数组中是否包含指定的元素。
array.includes(searchElement[, fromIndex])
// searchElement:要查找的元素。
// fromIndex(可选):从数组的哪个索引开始查找,默认为 0。如果指定了负数的 fromIndex,则从数组末尾向前查找。
const array = [1, 2, 3, 4, 5];
const element = 3;
const includesElement = array.includes(element);
console.log(includesElement); // true
// 指定索引开始下标
const array = [1, 2, 3, 4, 5];
const element = 3;
const fromIndex = 2;
const includesElement = array.includes(element, fromIndex);
console.log(includesElement); // false(从索引2开始查找,未找到元素3)
// 索引下标设置为负数
const array = [1, 2, 3, 4, 5];
const element = 1;
const fromIndex = -3; // 从数组倒数第3个元素开始查找
const includesElement = array.includes(element, fromIndex);
console.log(includesElement); // true(从倒数第3个元素开始查找,找到元素1)
copyWithin() 方法用于从数组的指定位置拷贝元素到数组的另一个指定位置中。
接收两个参数
第一个参数为粘贴的位置下标
第二个参数是开始复制的位置下标
第三个参数是结束复制的位置下标
//将数组的前两个元素复制到数组的最后两个位置
let arr = [1, 2, 3, arr , 5];
arr.copyWithin(3, 0);
console.log(arr); //[1,2,3,1,2]
let arr = [1, 2, 3, arr , 5, 9, 17];
//从索引3的位置开始粘贴
//从索引0的位置开始复制
//遇到索引3时停止复制
arr.copyWithin(3, 0, 3);
console.log(arr); //[1,2,3,1,2,3,17]
flat() 方法会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。
该方法返回一个新数组,对原数据没有影响。
参数: 指定要提取嵌套数组的结构深度,默认值为 1。
const arr1 = [0, 1, 2, [3, 4]];
console.log(arr1.flat());
// expected output: [0, 1, 2, 3, 4]
const arr2 = [0, 1, 2, [[[3, 4]]]];
console.log(arr2.flat(2));
// expected output: [0, 1, 2, [3, 4]]
//使用 Infinity,可展开任意深度的嵌套数组
var arr4 = [1, 2, [3, 4, [5, 6, [7, 8, [9, 10]]]]];
arr4.flat(Infinity);
// [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
// 扁平化数组空项,如果原数组有空位,flat()方法会跳过空位
var arr4 = [1, 2, , 4, 5];
arr4.flat();
// [1, 2, 4, 5]
对原数组的每个成员执行一个函数,相当于执行Array.prototype.map(),然后对返回值组成的数组执行flat()方法。
// 相当于 [[2, 4], [3, 6], [4, 8]].flat()
[2, 3, 4].flatMap((x) => [x, x * 2])
// [2, 4, 3, 6, 4, 8]
entries(),keys()和values() —— 用于遍历数组。它们都返回一个遍历器对象,可以用for…of循环进行遍历
区别是keys()是对键名的遍历、values()是对键值的遍历,entries()是对键值对的遍历
for (let index of [ a , b ].keys()) {
console.log(index);
}
// 0
// 1
for (let elem of [ a , b ].values()) {
console.log(elem);
}
// a
// b
for (let [index, elem] of [ a , b ].entries()) {
console.log(index, elem);
}
// 0 "a"
// 1 "b"
如果不使用for…of循环,可以手动调用遍历器对象的next方法,进行遍历。
let letter = [ a , b , c ];
let entries = letter.entries();
console.log(entries.next().value); // [0, a ]
console.log(entries.next().value); // [1, b ]
console.log(entries.next().value); // [2, c ]
push 向数组末尾添加数据
let arr = [1, 2, 3, 4, 5]
arr.push(6) // 返回值:返回的是添加元素后数组的长度.
console.log('push', arr); // [1, 2, 3, 4, 5, 6]
unshift 向数组前面添加数据
let arr = [1, 2, 3, 4, 5]
arr.unshift(0) // 6 返回的是添加元素后数组的长度
console.log('unshift', arr); // [0, 1, 2, 3, 4, 5, 6]
pop 删除末尾元素元素
let arr = [1, 2, 3, 4, 5]
arr.pop() // 5 返回值:返回的是刚才删除的元素.
console.log('pop', arr); // [1, 2, 3, 4]
shift 删除前面的元素
let arr = [1, 2, 3, 4, 5]
arr.shift() // 1 返回值:返回的是刚才删除的元素.
console.log('shift', arr); // [2, 3, 4, 5]