// 1.join方法将数组中的数据以指定字符分割成字符串,不影响原数组
/* let arr = [1,2,3,4,5]
console.log(arr.join(","))
console.log(arr.join("??"))
// 创建一个空的数组,组合之后就变成了三个间隔字符串的整合
console.log(new Array(4).join("??"))
console.log(arr) */
console.log("---------------------------------")
// 2.push()末尾添加任意数量参数,返回修改数组长度
// pop()末尾移除最后一项,改变length,返回移除项
/* let arr = [1, 2, 3, 4, 5, "???"]
let changeArr = arr.push("a", 'b')
console.log(arr)
console.log(changeArr)//输出的是更改后的长度
let popArr = arr.pop();
console.log(arr)
console.log(popArr) */
// 3.shift[去除的意思]删除原数组第一项,与pop对应
// unshift()在前面添加任意数量参数,与push对应
/* let arr = [1, 2, 3, 4, 5, "???"]
let changeArr = arr.unshift("a", 'b')
console.log(arr)
console.log(changeArr)//输出的是更改后的长度
let popArr = arr.shift();
console.log(arr)
console.log(popArr) */
// 4.sort()升序排序,调用每一项的toString方法比较字符串
// 可以穿入一个函数进行操作arr.sort(compare)
// compare是一个自定义的比较函数
// reverse()数组倒置,会改变原数组
/* let arr = [12, 23, 11, 35, 23, ""]
console.log(arr.sort())
console.log(arr)//原数组被改变
console.log(arr.reverse())
console.log(arr)//原数组被改变 */
// 5.concat() :将参数添加到原数组中。
// 这个方法会先创建当前数组一个副本,
// 然后将接收到的参数添加到这个副本的末尾,
// 最后返回新构建的数组。在没有给 concat()方法传递参数的情况下,
// 它只是复制当前数组并返回副本。
/* let arr = [1, 3, 5, 7];
let arrCopy = arr.concat(9, [11, 13]);
console.log(arrCopy); //[1, 3, 5, 7, 9, 11, 13]
console.log(arr); // [1, 3, 5, 7](原数组未被修改)
let arrCopy2 = arr.concat([9, [11, 13]]);
console.log(arrCopy2); //[1, 3, 5, 7, 9, Array[2]]
console.log(arrCopy2[5]); //[11, 13] */
// 6.slice():返回从原数组中指定开始下标到结束下标之间的项组成的新数组。
/* var arr = [1, 3, 5, 7, 9, 11];
var arrCopy = arr.slice(1);
var arrCopy2 = arr.slice(1, 4);
var arrCopy3 = arr.slice(1, -2);
var arrCopy4 = arr.slice(-4, -1);
console.log(arr); //[1, 3, 5, 7, 9, 11](原数组没变)
console.log(arrCopy); //[3, 5, 7, 9, 11]
console.log(arrCopy2); //[3, 5, 7]
console.log(arrCopy3); //[3, 5, 7]
console.log(arrCopy4); //[5, 7, 9] */
// 7.splice() :很强大的数组方法,它有很多种用法,可以实现删除、插入和替换。
// 删除:可以删除任意数量的项,只需指定 2 个参数:要删除的第一项的位置和要删除的项数。
// 例如, splice(0, 2)会删除数组中的前两项。
// 插入:可以向指定位置插入任意数量的项,只需提供 3 个参数:起始位置、 0(要删除的项数)和要插入的项。
// 例如,splice(2, 0, 4, 6)会从当前数组的位置 2 开始插入4和6。
// 替换:可以向指定位置插入任意数量的项,且同时删除任意数量的项,
// 只需指定 3 个参数:起始位置、要删除的项数和要插入的任意数量的项。插入的项数不必与删除的项数相等。
// 例如,splice(2, 1, 4, 6)会删除当前数组位置 2 的项,然后再从位置 2 开始插入4和6。
// splice()方法始终都会返回一个数组,该数组中包含从原始数组中删除的项,如果没有删除任何项,则返回一个空数组。
// 9、indexOf()和 lastIndexOf()
// indexOf() :接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的开头(位置 0)开始向后查找。
// lastIndexOf:接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的末尾开始向前查找。
// 这两个方法都返回要查找的项在数组中的位置,或者在没找到的情况下返回 - 1。在比较第一个参数与数组中的每一项时,会使用全等操作符。
// var arr = [1, 3, 5, 7, 7, 5, 3, 1];
// console.log(arr.indexOf(5)); //2
// console.log(arr.lastIndexOf(5)); //5
// console.log(arr.indexOf(5, 2)); //2
// console.log(arr.lastIndexOf(5, 4)); //2
// console.log(arr.indexOf("5")); //-1
// 10、forEach()
// forEach() :对数组进行遍历循环,对数组中的每一项运行给定函数。这个方法没有返回值
// var arr = [1, 2, 3, 4, 5];
// arr.forEach(function (x, index, a) {
// console.log(x + '|' + index + '|' + (a === arr));
// });
// // 输出为:
// // 1|0|true
// // 2|1|true
// // 3|2|true
// // 4|3|true
// // 5|4|true
// 11、map()
// map() :指“映射”,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
// 下面代码利用map方法实现数组中每个数求平方。
// var arr = [1, 2, 3, 4, 5];
// var arr2 = arr.map(function (item) {
// return item * item;
// });
// console.log(arr2); //[1, 4, 9, 16, 25]
// 12、filter()
// filter() :“过滤”功能,数组中的每一项运行给定函数,返回满足过滤条件组成的数组。
// var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
// var arr2 = arr.filter(function (x, index) {
// return index % 3 === 0 || x >= 8;
// });
// console.log(arr2); //[1, 4, 7, 8, 9, 10]
// 13、every()
// every() :判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。
// var arr = [1, 2, 3, 4, 5];
// var arr2 = arr.every(function (x) {
// return x < 10;
// });
// console.log(arr2); //true
// var arr3 = arr.every(function (x) {
// return x < 3;
// });
// console.log(arr3); // false
// 14、some()
// some() :判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
// var arr = [1, 2, 3, 4, 5];
// var arr2 = arr.some(function (x) {
// return x < 3;
// });
// console.log(arr2); //true
// var arr3 = arr.some(function (x) {
// return x < 1;
// });
// console.log(arr3); // false