JavaScript常用数组操作方法
一、concat()方法
用于连接两个或多个数组。该方法不会改变原来的数组,仅会返回被连接数组的一个副本。
let arr = [1,3,4]
let arr1 = [5,6,7]
console.log(arr.concat(arr1)) // [1, 3, 4, 5, 6, 7]
console.log(arr) // [1, 3, 4]
console.log(arr1) // [5, 6, 7]
二、join()方法
用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的,
默认使用','号分割,不改变原数组。
let arr = [1,3,4]
console.log(arr.join()) // 1,3,4
console.log(arr.join("")) // 134
console.log(arr.join(":")) // 1:3:4
console.log(arr) // [1, 3, 4]
三、push()方法
可向数组的末尾添加一个或多个元素,并返回新的长度。末尾添加,返回的是长度,
会改变原数组。
let arr = [4,8]
let arr2 = arr.push(6)
console.log(arr2) //3 返回新的长度3
console.log(arr) // [4, 8, 6] //会改变原数组,末尾添加
四、pop()方法
用于删除数组的最后一个元素。并返回最后一个元素,会改变原数组。
var arr = [5,6,7];
console.log(arr.pop()); // 7
console.log(arr); // [5,6]
五、shift()方法
用于把数组的第一个元素从其中删除,并返回第一个元素的值。返回第一个元素,改变原数组。
var arr = [5,6,7];
console.log(arr.shift()); // 5
console.log(arr); // [6,7]
六、unshift()方法
可向数组的开头添加一个或更多元素,并返回新的长度。返回新长度,改变原数组。
该方法可以不传参数,不传参数就是不增加元素。
var arr = [2,3,4,5];
console.log(arr.unshift(3,6)); //6
console.log(arr); //[3, 6, 2, 3, 4, 5]
七、slice()方法
可从已有的数组中返回选定的元素。
返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。
返回选定的元素,该方法不会修改原数组。
注释:您可使用负值从数组的尾部选取元素。
注释:如果 end 未被规定,那么 slice() 方法会选取从 start 到数组结尾的所有元素。
八、splice()方法
向/从数组中添加/删除项目,然后返回被删除的项目。
该方法会改变原始数组。
splice(index,len,[item])
它也可以用来替换/删除/添加数组内某一个或者几个值(该方法会改变原始数组)
index:数组开始下标
len: 替换/删除的长度
tem:替换的值,删除操作的话 item为空
var arr = ['a','b','c','d'];
删除:
arr.splice(1,1); // 删除起始下标为1,长度为1的一个值(len设置1,如果为0,则数组不变)
替换
arr.splice(1,1,'ttt'); // 替换起始下标为1,长度为1的一个值为‘ttt’,len设置的1
添加
arr.splice(1,0,'ttt'); // 在下标为1处添加一项'ttt'
九、substring() 和 substr()方法
相同点:如果只是写一个参数,两者的作用都一样:
substr(startIndex);// 截取字符串从当前下标以后直到字符串最后的字符串片段
substring(startIndex);// 截取字符串从当前下标以后直到字符串最后的字符串片段
不同点:第二个参数
// 第二个参数是截取字符串的长度,从起始点截取某个长度的字符串
substr(startIndex,lenth)
// 第二个参数是截取字符串最终的下标 (截取2个位置之间的字符串,‘含头不含尾’)。
substring(startIndex, endIndex)
十、reverse()方法
用于颠倒数组中元素的顺序。返回的是颠倒后的数组,会改变原数组。
var arr = [2,3,4];
console.log(arr.reverse()); //[4, 3, 2]
console.log(arr); //[4, 3, 2]
十一、indexOf 和 lastIndexOf
返回一个指定的字符串值最后出现的位置,在一个字符串中的指定位置从后向前搜索
都接受两个参数:查找的值、查找起始位置
不存在,返回 -1 ;存在,返回位置。indexOf 是从前往后查找, lastIndexOf 是从后往前查找。
var a = [2, 9, 9];
a.indexOf(2); // 0
a.indexOf(7); // -1
var numbers = [2, 5, 9, 2];
console.log(numbers.lastIndexOf(2)) // 3
十二、every方法
对数组的每一项都运行给定的函数,每一项都返回 ture,则返回 true
function isBigEnough(element, index, array) {
return element < 10;
}
[2, 5, 8, 3, 4].every(isBigEnough); // true
十三、some方法
对数组的每一项都运行给定的函数,任意一项都返回 ture,则返回 true
function compare(element, index, array) {
return element > 10;
}
[2, 5, 8, 1, 4].some(compare); // false
[12, 5, 8, 1, 4].some(compare); // true
十四、filter()方法
会创建一个新数组,原数组的每个元素传入回调函数中,回调函数中有return返回值,
若 返回值为true,这个元素保存到新数组中;
若返回值为false,则该元素不保存到新数组中;
原数组不发生改变。
。