JS数组概览(汇总)

一、JS数组概览(汇总)

1、find、findIndex

find:返回符合条件的第一个元素
findIndex: 返回符合条件的第一个元素的位置(下标)

let arr = [1,2,3,4,5];
let index = arr.findIndex(item=>{
  return item % 2 === 0
}) 
// index ========= 1

2、 splice

splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。会改变原数组
语法:array.splice(index,howmany,item1,…,itemX)

实例:删除数组中的元素

var arr = [1,2,2,3,4,5,6];
var len = arr.length;
// 方法一(常规操作)
for(var i=0;i<len;i++){ 
  if(arr[i]==2){ // 删除所有为2的元素
    arr.splice(i,1);
    i--;
  }
}

// 方法二(从后往前遍历,代码更简单)
for(var i=len;i>=0;i--){
  if(arr[i]==2){
    arr.splice(i,1);
  }
}

// 方法三 (while)
while(i--){
  if(arr[i]==2){
    arr.splice(i,1);
  }
}

实例:指定位置添加元素

var arr= ["1", "2", "3", "4"];
arr.splice(2, 0, "111", "222"); // ["1","2","111","222","3","4"]

3、slice

slice(start,end)提取字符串的某个部分,并以新的字符串返回被提取的部分
不会改变原数组

/**
 * [1,2,3,4,5,6,7,8,9,10] => [[1,2,3],[4,5,6],[7,8,9],[10]]
 * size:3
 */
let arr = Array.from(new Array(10), (x, index) => {
  return index + 1
})
function getResultGroup(result,size) { 
  let arr1 = [];
  let len = result.length;
  for(let i = 0; i< len; i = i + size) {
    let arr2 = result;
    arr1.push(arr2.slice(i,i + size))
  }
  return arr1;
}

4、concat

concat() 方法用于连接两个或多个数组
返回一个新的数组,不会改变原数组

let arr1 = new Array(1,2,3);
let num = 4;
let arr2 = [5,6];
console.log(arr1.concat(num,arr2)) // [1,2,3,4,5,6]

5、indexOf

语法:Array.indexOf(a)
从数组头部开始查找某项,返回索引值(找到的第一个索引值),找不到返回-1

  • 案例-数组去重
// filter 遍历数组返回执行结果为true的项,组成一个新数组
let arr = [1,2,3,4,5,4,3,2,1];
let newArr = arr.filter((item,index)=>{
  return arr.indexOf(item) === index
})
console.log(newArr) // 返回 [1,2,3,4,5]

6、map

语法:array.map(function(currentValue,index,arr), thisValue)
参数:接收两个参数,一个是回调函数,另一个是回调函数的this值(可选)。回调函数接收三个参数,分别是当前值,当前索引和整个数组。
返回:函数返回一个新创建的数组,数组中的每个元素都经过了回调函数的处理,结果不改变原数组

let nums = [1, 2, 3];
let obj = {val: 5};
let newNums = nums.map(function(item,index,array) {
  return item + index + array[index] + this.val; 
  //对第一个元素,1 + 0 + 1 + 5 = 7
  //对第二个元素,2 + 1 + 2 + 5 = 10
  //对第三个元素,3 + 2 + 3 + 5 = 13
}, obj);
console.log(newNums);//[7, 10, 13]

7、filter

语法:array.filter(function(currentValue,index,arr), thisValue)
参数:接收一个函数参数。函数接收一个默认参数,就是数组正在遍历的当前元素,函数参数的返回值是一个布尔值,若返回true,则数组元素得到保留。
返回:返回该函数会返回true的项组成的数组,此函数不会改变原数组

let data = [ { id: 1, check: true }, {id: 2, check: false} { id: 4, check: true } ]
let newData = data.filter(item=>{
  return item.check;
});
console.log(newData); // 返回true的项组成的数组 

8、every和some

some:判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
every:判断数组中每一项是否都满足条件,只有所有项都满足条件,才会返回true

// every
let data = [{id: 1, check: true},{id: 2, check: false},
	{id: 3, check: false},{id: 4, check: true}];
	
let selectAll = data.every(item=>{
   return item.check;
});
console.log("every函数:"+selectAll) // data中每一项都为true才会返回true

// some
let hasCheck = data.some(item=>{
    return item.check;
});
console.log("some函数:"+hasCheck); // data中任一一项返回true则会返回true

9、reduce

语法:reduce(callback,initiaValue)会传入两个变量,回调函数(callback)和初始值(initiaValue)。
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。对空数组是不会执行回调函数的。

案例:

  • 计算数组总和
var num = [1,2,3,4,5];
var res = num.reduce(function(total,num){
    return total+num;
},0);
console.log(res)//15
  • 合并二维数组
var red = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {
 return a.concat(b);
}, []);
console.log(red) // [0, 1, 2, 3, 4, 5]
  • 统计一个数组中有多少个不重复的单词
// 不用reduce时:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
  var obj = {};
  for(var i= 0, l = arr.length; i< l; i++){
    var item = arr[i];
    obj[item] = (obj[item] +1 ) || 1;
  }
  return obj;
}
console.log(getWordCnt()); // {apple: 2, orange: 3, pear: 1}

// 用reduce时:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
  return = arr.reduce(function(prev,next) {
    prev[next] = (prev[next] + 1) || 1;
    return prev;
  },{})
}
console.log(getWordCnt()); // {apple: 2, orange: 3, pear: 1}

10、Array.from()

  • 将具有length属性的对象 转成数组
let arrayLike = {
  '0': 'a',
  '1': 'b',
  '2': 'c',
  length: 3
};
// ES5
let arr = Array.prototype.slice.call(arrayLike);
// ES6
let arr1 = Array.from(arrayLike);
console.log(arr); //['a','b','c'];
console.log(arr1); //['a','b','c'];

补充:关于slice大致内部实现

Array.prototype.slice = function(start,end){
     var result = new Array();
     start = start || 0;
     //this指向调用的对象,当用了call后,能够改变this的指向,也就是指向传进来的对象
     end = end || this.length; 
     for(var i = start; i < end; i++){
          result.push(this[i]);
     }
     return result;
}
  • Array.from()方法的第二个参数

Array.from()方法的第二个参数类似与数组的map方法,用于对每个元素进行处理,并将处理后的结果放入返回的数组。

let arrayLike = {
    '0': 1,
    '1': 2,
    '2': 3,
    length: 3
};
// ES6
let arr1 = Array.from(arrayLike, ele => ele + 1); //[2,3,4]
// ES5
let arr2 = Array.prototype.map.call(arrayLike, ele => ele + 1); //[2,3,4]
// 等同于
let arr3 = Array.from(arrayLike).map(ele => ele + 1); //[2,3,4];
  • 举例:快速生成包含10个数字1的数组
let arrayLike = {length: 10};
let arr = Array.from(arrayLike, () => 1);
  • 举例:生成数字范围
function range(end) {
 return Array.from({ length: end }, (_, index) => index)
}
console.log(range(4)); // => [0, 1, 2, 3]

拓展

数组的拷贝
arrayObj.slice(0); //返回数组的拷贝数组,注意是一个新的数组,不是指向
arrayObj.concat(); //返回数组的拷贝数组,注意是一个新的数组,不是指向

数组元素的字符串化
arrayObj.join(separator); //返回字符串
let arr = [1,2,3,4,5,6];
console.log(arr.join(',')) // 1,2,3,4,5,6

数组排序
arrayObj.sort()   arrayObj.reverse()
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值