首页 > 其他分享 >工作中需知道的数组方法总结

工作中需知道的数组方法总结

时间:2023-01-12 18:36:17浏览次数:49  
标签:总结 arr const 中需 item 数组 console log

数组遍历操作
  • forEach 该方法等同于for循环,其没有返回值
    结构:arr.forEach(回调函数,回调函数this的值) 第二个参数当回调函数是箭头函数时无效
用法:
arr.forEach(function(item,index,arr){
// 里面的function是一个回调函数
// item: 数组中的每一项
// index:item 对应的下标索引值
// arr: 就是调用该方法的数组本身
});
  • map 该方法使用和forEach大致相同,该方法有返回值,返回一个新数组,工作中需要对数组的每一项进行操作获取操作后的新数组时可以使用此方法
    结构:arr.map(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const newArr= arr.map((item,index,arr) => {
return item * 2;
});
console.log(newArr); // [2,4,6]
console.log(arr); // [1,2,3]
注:当数组元素类型为引用类型时会改变原数组,因为值类型入参是复制,引用类型是指向同一对象
const arr2 = [{num:1},{num:2},{num:3}];
const newArr2 = arr2.map((item,index,arr) => {
item.num2 = 10;
return item;
});
console.log(newArr2); // [{num: 1, num2: 10},{num: 2, num2: 10},{num: 3, num2: 10}]
console.log(arr2); // [{num: 1, num2: 10},{num: 2, num2: 10},{num: 3, num2: 10}]
  • filter 该方法有返回值,返回一个符合条件元素组成的新数组,工作中需要过滤出符合条件的数组元素时可以使用此方法
    结构:arr.filter(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const newArr= arr.filter((item,index,arr) => {
return item > 2;
});
console.log(newArr); // [3]
  • some 该方法判断数组中有没有符合条件的项(只要有,就返回true),如果一个都没有才返回false,原理类似于或运算
    结构:arr.some(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const flag = arr.some((item,index,arr) => {
return item > 2;
});
console.log(flag); // true
const flag2= arr.some((item,index,arr) => {
return item > 4;
});
console.log(flag2); // false
  • every 该方法判断数组中所有的项是否满足要求,如果全都满足才返回true,否则返回false,原理类似于与运算
    结构:arr.every(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const flag = arr.every((item,index,arr) => {
return item > 0;
});
console.log(flag); // true
const flag2= arr.every((item,index,arr) => {
return item > 1;
});
console.log(flag2); // false
数组增删改操作
  • push 该方法可以在数组的最后面增加一个或多个元素,返回值为添加新元素后数组的长度
    结构:arr.push(值)
例:
const arr = [1,2,3];
const arrLength = arr.push(4,5,6);
console.log(arr); // [1,2,3,4,5,6]
console.log(arrLength); // 6
  • pop 该方法为删除数组的最后一位元素,返回值为删除的那个元素
    结构:arr.pop()
例:
const arr = [1,2,3];
const arrLength = arr.pop();
console.log(arr); // [1,2]
console.log(arrLength); // 3
  • unshift 该方法可以在数组的最前面增加一个或多个元素,返回值为添加新元素后数组的长度
    结构:arr.unshift(值)
例:
const arr = [1,2,3];
const arrLength = arr.unshift(0);
console.log(arr); // [0,1,2,3]
console.log(arrLength); // 4
  • shift 该方法为删除数组第一位元素,返回值为删除的元素
    结构:arr.shift()
例:
const arr = [1,2,3];
const arrLength = arr.shift();
console.log(arr); // [2,3]
console.log(arrLength); // 1
  • splice 该方法可以实现删除或增加或替换元素(任意在任何位置,直接改变原数组,没有返回值)
    结构:arr.splice(开始下标位置,处理的个数,新增的元素1,新增的元素2...)
例:
const arr = [1,2,3,4,5,6];
arr.splice(0,2); // 纯删除
console.log(arr); // [3,4,5,6];
arr.splice(1,1,7); // 替换
console.log(arr); // [3,7,5,6]
arr.splice(1,0,8,9); // 纯添加
console.log(arr); // [3,8,9,7,5,6]
检查数组是否包含某个元素
  • includes 该方法可直接检测数组中是否包含某个元素,包含则返回true,不包含则返回false
    结构:arr.includes(值,从某个下标开始)
例:
const arr = [1,2,3];
const flag1 = arr.includes(2);
const flag2 = arr.includes(4) ;
const flag3 = arr.includes(2,2);
console.log(flag1); // true
console.log(flag2); // false
console.log(flag3); // false
  • indexOf 该方法可检测数组中是否包含某个元素,包含则返回第一个匹配元素的索引,不包含则返回-1
    结构:arr.indexOf(值,从某个下标开始)
例:
const arr = [1,2,3,5,2];
const flag1 = arr.indexOf(2);
const flag2 = arr.indexOf(4) ;
const flag3 = arr.indexOf(2,2);
console.log(flag1); // 1
console.log(flag2); // -1
console.log(flag3); // 4
  • lastIndexOf 该方法可检测数组中是否包含某个元素,包含则返回元素的最后一个索引,不包含则返回-1
    结构:arr.lastIndexOf(值,从某个下标开始)
例:
const arr = [1,2,3,4,2,5,6,2];
const flag1 = arr.lastIndexOf(2);
const flag2 = arr.lastIndexOf(9);
console.log(flag1); // 7
console.log(flag2); // -1
数组拼接与截取
  • join 该方法可以将数组里的元素,通过指定的分隔符,以字符串的形式拼接起来,默认是以,分割
    结构:arr.join(分隔符)
例:
const arr = [1,2,3];
const str1 = arr.join();
const str2 = arr.join('-');
console.log(str1); // 1,2,3
console.log(str2); // 1-2-3
  • concat 该方法可以把两个数组里的元素拼接成一个新的数组
    结构:arr.concat(值1, 值2)
例:
const arr1 = [1,2,3];
const arr2 = [4,5,6];
const arr = arr1.concat(arr2,7,8,[9,10]);
console.log(arr) //[1,2,3,4,5,6,7,8,9,10];
  • slice 该方法可以从数组中截取指定的元素段,返回出来,不改变原数组,入参都是可选参数
    结构:arr.slice(开始位,结束位)
例:
const arr = [1,2,3,4,5,6];
const arr1 = arr.slice(); //截取全部
const arr2 = arr.slice(2); //开始位开始往后截取全部
const arr3 = arr.slice(2,5); //开始位开始,不包括结束位元素
console.log(arr1); //[1,2,3,4,5,6]
console.log(arr2); //[3,4,5,6]
console.log(arr3); //[3,4,5]
数组的翻转与排序
  • reverse 该方法将数组中元素的位置颠倒,并返回该数组,会改变原数组
    结构:arr.reverse()
例:
const arr = [1,2,3];
arr.reverse()];
console.log(arr); // [3,2,1]
  • sort 该方法对数组的元素进行排序,并返回数组
    结构:arr.sort(函数)
例:
const arr = [1,5,2,6,9,7,3];
arr.sort(); // 默认排序,会将元素转换为字符串,然后比较它们的 UTF-16 代码单元值实现排序
console.log(arr); // [1, 2, 3, 5, 6, 7, 9]
const arr1 = [1,5,2,6,9,7,3];
arr1.sort((a, b) => { return a - b }); // 自定义排序,递增
console.log(arr1); // [1, 2, 3, 5, 6, 7, 9]
const arr2 = [1,5,2,6,9,7,3];
arr2.sort((a, b) => { return b - a }); // 自定义排序,递减
console.log(arr2); // [9, 7, 6, 5, 3, 2, 1]

标签:总结,arr,const,中需,item,数组,console,log
From: https://blog.51cto.com/u_15938015/6004572

相关文章

  • Java数组
    数组数组概述相同数据类型的数据有序集合描述相同类型的若干个数据,按照一定的先后次序排列组合一起数组里的每一个数据称作一个数组元素,每个数组元素可以通......
  • JS_3_数组
    JavaScript中的数组是自动扩容的。灵活地!  声明:1、vararr=newArray();2、vararr=newArray(length);3、vararr=[];赋值和取值:通过......
  • 1.将树形结构数据打平成一维数组
    1.函数constflatTree=(treeData)=>{letresult=[];treeData.forEach((item)=>{//先克隆一份数据作为第一层级的填充letres=JSON.parse(JSON......
  • 2022 年度总结
    前言写这篇博客的起因是,公司要求写年度个人总结。我翻了下网上的总结,都不太符合自己的情况,于是打算真情实感地原创一篇。年度总结,无非就是梳理下有没有完成年初的flag,再......
  • LeetCode刷题(11)~ 两个数组的交集 II
    题目描述给定两个数组,编写一个函数来计算它们的交集。示例1:输入:nums1=[1,2,2,1],nums2=[2,2]输出:[2,2]示例2:输入:nums1=[4,9,5],nums2=[9,4,9,8,4]输出:[4,9]......
  • LeetCode刷题(8)~旋转数组
    题目描述给定一个数组,将数组中的元素向右移动k个位置,其中k是非负数。示例1:输入:[1,2,3,4,5,6,7]和k=3输出:[5,6,7,1,2,3,4]解释:向右旋转1步:[7,1,2,3,4,5,6......
  • LeetCode刷题(7)~删除排序数组中的重复项
    题目描述给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用......
  • LeetCode刷题(59)~使数组中所有元素相等的最小操作数【第202场周赛:题目二】
    题目描述存在一个长度为n的数组arr,其中arr[i]=(2*i)+1(0<=i<n)。一次操作中,你可以选出两个下标,记作x和y(0<=x,y<n)并使arr[x]减去1、arr[y]......
  • leetcode_数据结构_入门_350. 两个数组的交集 II
    350.两个数组的交集II 给两个整数数组 nums1和nums2,请以数组形式返回两数组的交集(其在交集中出现的次数:等于该数字在两个数组中出现次数的最小值)。返......
  • 1月12日内容总结——文件和文件索引、链接、系统时间、克隆、定时任务、paramiko模块
    目录一、文件相关信息二、文件索引信息三、链接信息四、系统时间五、机器克隆六、定时任务七、paramiko模块八、公钥私钥九、paramiko其他操作十、代码封装十一、面试题回......