数组方法
在日常的开发中,经常会遇到数组的操作。
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(1,4);
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
认真做事儿,踏实做人

浙公网安备 33010602011771号