数组方法

在日常的开发中,经常会遇到数组的操作。

1、join方法,把数组转换成字符串,默认逗号分割(  ,)

const arr = [1,2,3];
console.log(arr.join());     // 1,2,3
console.log(arr.join("-"));   // 1-2-3
console.log(arr);         // [1, 2, 3](原数组不变)

2、push()添加到数组末尾,并返回修改后的长度;pop()移除数组最后一项,返回移除的那个值减少数组的length

const arr = ["apple","banner","tomato"];
var newArray= arr.push("pear");
console.log(newArray);    // 4
console.log(arr);       // ["apple", "banner", "tomato", "pear"]
var item = arr.pop();
console.log(item);            // pear
console.log(arr);  

3、shift()删除原数组的第一项,返回删除元素的值,如果数组为空则返回undefined。unshift()将参数添加到原数组开头,并返回数组长度

const array = ["Lily","lucy","Tom"];
const count = array.unshift("Jack","Sean");
console.log(count);     // 5

var item = array.shift();
console.log(item);     // Jack

4、sort()将数组从小到大排序

const sortArray = ["a", "d", "c", "b"]
console.log(sortArray .sort()); // ["a", "b", "c", "d"]

sort()方法比较的是字符串,实现对数值排序,添加排序函数

function sortNum(a,b){
  return a - b
}

numArray = [13, 24, 51, 3] 
console.log(numArray.sort())  // [13, 24, 3, 51] 
console.log(numArray.sort(sortNum)) // [3, 13, 24, 51]

5、concat()将参数添加到原数组中,并返回一个新数组。原数组未改变

const arr = [1,3,5,7];
const arrCopy = arr.concat(9,[11,13]);
console.log(arrCopy);      //[1, 3, 5, 7, 9, 11, 13]

6、slice()返回从指定下标位置开始到结束下标之间的新数组

如果是一个参数,则从指定位置开始到数组末尾。
const array= [1,3,5,7,9,11];
const sliceArray = array.slice(1);

如果是俩个参数,则从指定位置开始到指定位置结束。
const array= [1,3,5,7,9,11];
const sliceArray = array.slice(14);

7、splice()删除、插入、替换

删除:指定删除的位置和个数
arr.splice( 1 , 3 ) // 从下标1开始,删除3个数值

插入:从指定位置插入任意的数
arr.splice(2,0,4,6)

var arr = [1,3,5,7,9,11];
var arrRemoved = arr.splice(0,2);

console.log(arr);           //[5, 7, 9, 11]
console.log(arrRemoved);      //[1, 3]

var arrRemoved2 = arr.splice(2,0,4,6);
console.log(arr);          // [5, 7, 4, 6, 9, 11]
console.log(arrRemoved2);    // []

var arrRemoved3 = arr.splice(1,1,2,4);
console.log(arr);          // [5, 2, 4, 4, 6, 9, 11]
console.log(arrRemoved3);        //[7]

8、indexOf()查找指定项数值,并返回下标

const array = [1,2,3,4,5]

array.indexOf(4) //返回3

9、forEach()对数组遍历循环,参数是function类型,分别对应数组各项的值,下标值,数组本身

const array = [1, 2];
array.forEach(function(x, index, a){
console.log(x + '|' + index + '|' + (a === arr));
});

// 1-0-true;2-1-true

10、map(),对数组循环,返回每一项给定函数结果

const array = [1, 2];
var array2 = array.map(function(item){
return item*item;
});

// [1,4]

11、filter()数组过滤方法,返回满足条件的数组

const array = [1, 2];
var array2= array.filter(function(x, index) {
return index % 2 === 0
}); 

12、every()判断数组中每一项是否满足条件,只有都满足返回true

13、some()判断数组中是否存在满足条件的项,有一项满足返回true

posted @ 2021-04-29 16:58  逩跑得前端小学生  阅读(66)  评论(0)    收藏  举报