位置: IT常识 - 正文

JavaScript ,18种常用数组方法,快来看看你会吗?

编辑:rootadmin
JavaScript ,18种常用数组方法,快来看看你会吗? 前言

推荐整理分享JavaScript ,18种常用数组方法,快来看看你会吗?,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

众所周知,向后端请求数据,处理数据是前端工程师必备的技能,从后端请求回来的数据往往是数组的形式返回到前端,因此数组处理方法的重要性可想而知;数组的处理方法在MDN文档上很多,很多朋友在学习时往往会抓不住重点,导致事倍功半,但是大家不要担心,我已经为大家总结了工作中常用的18种数组处理的方法,大家一定要牢记哦!

文章の目录前言不会改变原数组的方法forEach()方法filter()方法map()方法findIndex()方法find()方法some()方法every()方法reduce()归纳函数concat()数组拼接改变原数组的方法push()/unshift()pop()/shift()sort()/reverse()splice()其它flat()fill()写在最后不会改变原数组的方法forEach()方法

forEach()方法传入的参数是一个函数,内部传入的函数的形参第一个是item数组每一项的值,第二个是索引号index,它的返回值是undefined; 运行实例如下: 控制台输出结果

filter()方法

filter()方法是筛选数组的方法,传入的参数和forEach方法一样,但是返回值为一个数组,实际应用是用来将获取到的数据中符合条件的数组筛选出来; 运行的实例如下: 控制台输出结果如下:

map()方法

map()方法传入的参数也同上,它的返回值也是一个新的数组;map()方法可以对数组的每一项进行相同的处理,运行的实例如下:

控制台的输出结果:

findIndex()方法

findIndex()方法顾名思义,是返回数组中的符合条件的第一项的索引号,如果找不到返回-1。传入的参数同上,运行实例如下所示:

let arr = [1, 3, 3, 4, 5, 6, 7]//findIndex方法,返回第一个符合条件哪一项的索引号,找不到返回-1const res = arr.findIndex((item) => item > 5)console.log(res)

控制台输出结果:

find()方法

find()方法是返回查找到的第一个符合条件的那一项,传入的参数同上。运行实例如下所示:

let arr = [1, 3, 3, 4, 5, 6, 7]//find()查找item,返回第一个符合条件的那一项,找不带返回undefinedconst res2 = arr.find((item) => { return item > 5})console.log(res2)

控制台运行结果如下:

some()方法

some()方法传入的参数同上,返回值是布尔值,只要查找到一项符合条件就返回true;示例如下:

let arr = [1, 3, 3, 4, 5, 6, 7]//some方法返回布尔值const bl = arr.some((item) => { return item > 5})console.log(bl)

every()方法

every()方法传入的参数也是同上,返回值是布尔值,但是必须每一项都符合条件才返回true;示例如下:

let arr = [1, 3, 3, 4, 5, 6, 7]//every()返回值为布尔值需要全部通过筛选条件才返回trueconst bl2 = arr.every((currentValue) => { return currentValue < 10})console.log(bl2)

reduce()归纳函数JavaScript ,18种常用数组方法,快来看看你会吗?

reduce()函数中的参数第一个参数是函数,第二个参数是暂存变量sum的类型,第一个参数函数有四个参数,不过常用的就是第一个参数为累加暂存变量(return就是这个值),第二个参数item。第三个是index,第四个是数组本身;代码示例如下:

let arr = [1, 3, 3, 4, 5, 6, 7]//reduce()归纳函数const previousValue = 0const arrSum = arr.reduce((previousValue, currentValue) => { return previousValue + currentValue}, 0)console.log(arrSum)

控制台输出结果如下:

concat()数组拼接

concat()将两个数组进行拼接,返回的是拼接完的新数组,不能给多维数组(数组套数组)进行拼接; 代码示例如下:

let arr = [1, 3, 3, 4, 5, 6, 7]//concat 将两个数组进行拼接 , 返回的是一个新的数组const newArr3 = [2, 5, 5, 6, 6, 8]const concatArr = arr.concat(newArr3)console.log(concatArr)

改变原数组的方法push()/unshift()

push()/unshift()方法是分别在数组的最后面和最前面添加一个元素,返回值是新数组的长度;

//一下数组处理方法会改变原数组const Arr = [1, 3, 5, 6, 7, 8, 9]Arr.push(1)console.log(Arr)console.log(Arr)const a = Arr.unshift(1)console.log(a)

控制台输出结果如下:

pop()/shift()

此两种方法pop()是删除数组的最后一个值,shift()是删除数组的第一项的值;返回值是删除的那一项;

arr.pop(1)console.log(arr)arr.shift(1)console.log(arr)

控制台输出结果如下:

sort()/reverse()

sort()方法是排序,内部的参数是一个函数,function(a , b){ return a - b },通过此函数可以控制排序是降序函数升序,如果参数内部return a - b是降序,return a + b是升序; reverse()是数组翻转,即将数组的元素倒序排列;代码示例如下:

let arr = [1, 3, 3, 4, 5, 6, 7]arr.sort((a, b) => { return a - b})console.log(arr)arr.reverse()console.log(arr)

splice()

splice()方法修改原数组,返回一个删除元素的新数组,负数就是从后往前数索引;传入的第一个参数是删除的起始元素的索引号,第二个参数是删除的元素的个数;

let arr = [1, 3, 3, 4, 5, 6, 7]arr.splice(1, 3)console.log(arr)

其它flat()

flat()用于多维数组拍平,传入的参数是数组拍平的深度,也可以是infiniy,代表数组拍平的深度是无穷大 代码示例如下:

const Arr2 = [ [1, 2], [2, 3], [4, 5], [5, 6],]console.log(Arr2.flat(Infinity))

控制台输出结果:

fill()

可以对数组进行填充:写法:Array.fill(1 , 2 , 4)数组中填充1 , 从索引值是2的元素开始, 到元素的索引号是4开始,不包括索引值是4的元素;填充的元素会覆盖原来对应索引号的元素; 代码示例如下:

const Arr2 = [ [1, 2], [2, 3], [4, 5], [5, 6],]console.log(Arr2.fill(1, 0, 4))

控制台输出结果:

写在最后

到此18种常用数组方法已经讲解完毕,本文因为篇幅有限,部分的方法可能讲解不够详细,请大家谅解,如有疑问的地方,可以查询MDN文章,下面附上MDN文章,有问题的查询文档即可: MDN文档

🥂(❁´◡`❁)您的点赞👍➕评论📝➕收藏⭐是作者创作的最大动力🤞

本文链接地址:https://www.jiuchutong.com/zhishi/299488.html 转载请保留说明!

上一篇:uni-app--》什么是uniapp?如何开发uniapp?(uni-app是干嘛的)

下一篇:Docker在Windows环境的搭建和使用(docker windows -v)

  • 荣耀30青春版是5G的双模手机吗(荣耀30青春版是5g手机吗)

    荣耀30青春版是5G的双模手机吗(荣耀30青春版是5g手机吗)

  • 如何查看华为手机型号(如何查看华为手机激活日期)

    如何查看华为手机型号(如何查看华为手机激活日期)

  • windows7sp1是什么(windows7旗舰版sp1是什么意思)

    windows7sp1是什么(windows7旗舰版sp1是什么意思)

  • 苹果手机充电总是一响一响的(苹果手机充电总是反复断开)

    苹果手机充电总是一响一响的(苹果手机充电总是反复断开)

  • 微信把我拉黑了怎么给他发信息(前女友微信把我拉黑了)

    微信把我拉黑了怎么给他发信息(前女友微信把我拉黑了)

  • 淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

    淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

  • 华为电脑云端登录手机会提示吗(电脑登陆华为云账号会有提示吗)

    华为电脑云端登录手机会提示吗(电脑登陆华为云账号会有提示吗)

  • 图片格式的扫描件是什么(图片扫描文件格式)

    图片格式的扫描件是什么(图片扫描文件格式)

  • 爱奇艺自动续费能马上取消吗(爱奇艺自动续费怎么关)

    爱奇艺自动续费能马上取消吗(爱奇艺自动续费怎么关)

  • WPS电子表格输入数字后出现e 怎么办(wps怎么输入带圈数字)

    WPS电子表格输入数字后出现e 怎么办(wps怎么输入带圈数字)

  • 路由器信号满格但是没有网络怎么办(路由器信号满格却很卡)

    路由器信号满格但是没有网络怎么办(路由器信号满格却很卡)

  • gps一直开着耗电大吗(gps一直开着耗电快吗)

    gps一直开着耗电大吗(gps一直开着耗电快吗)

  • 新换的苹果不显示通讯录怎么办(快速开始 旧iphone没显示)

    新换的苹果不显示通讯录怎么办(快速开始 旧iphone没显示)

  • qq相册怎么上传照片(qq相册怎么上传大视频文件)

    qq相册怎么上传照片(qq相册怎么上传大视频文件)

  • 苹果7p充电慢正常吗(苹果7plus充电慢)

    苹果7p充电慢正常吗(苹果7plus充电慢)

  • 京东的热8是什么情况(京东热8购物持续多久)

    京东的热8是什么情况(京东热8购物持续多久)

  • 淘宝点过赞的内容在哪(淘宝点赞会被看到吗)

    淘宝点过赞的内容在哪(淘宝点赞会被看到吗)

  • 小米路由器3c是千兆吗(小米路由器3C是双频的吗)

    小米路由器3c是千兆吗(小米路由器3C是双频的吗)

  • 魅族16sPro怎么分享热点(魅族16thplus怎么分屏)

    魅族16sPro怎么分享热点(魅族16thplus怎么分屏)

  • 爱奇艺怎么切换清晰度(爱奇艺怎么切换手机号登录)

    爱奇艺怎么切换清晰度(爱奇艺怎么切换手机号登录)

  • 华为p30怎么设置屏幕亮的时间(华为p30怎么设置24小时)

    华为p30怎么设置屏幕亮的时间(华为p30怎么设置24小时)

  • 探探卸载了别人还能看到我吗(探探卸载了别人还能看到距离吗)

    探探卸载了别人还能看到我吗(探探卸载了别人还能看到距离吗)

  • 响了很久才用户正忙(响了很久用户正忙)

    响了很久才用户正忙(响了很久用户正忙)

  • 增值税普通发票怎么开
  • 小规模纳税人的账务处理
  • 城建税和教育费附加减免政策
  • 小规模纳税人税费会计分录
  • 国库券利息收入计入利润总额吗
  • 个人独资企业增值税税率是多少
  • 钱收多了退回去怎么说好
  • 捐赠的营业外收入怎么算
  • 所得税申报表里季初资产是指什么
  • 企业发生破产清算
  • 企业承担的员工在职培训成本包括
  • 债权投资类会计账务处理
  • 微信公众订阅号怎么注册
  • 以前年度固定资产入账错误怎么办?
  • 负债表应交税费为负数
  • 企业所得税季报资产总额怎么填
  • 工资不在本单位拿取的能加入会员吗
  • 发票跨年冲销
  • 直接快递到国外的货物如何收汇?
  • 商业土地厂房办公房过户需要交什么税?
  • 结转主营业务成本是含税还是不含税
  • 注销税务登记后多久注销工商登记
  • 宏基笔记本电脑售后电话
  • 没收到电费账单怎么办
  • 一年内的待摊费用可以一次性进入成本吗
  • 把原材料给别人加工怎么入账
  • 营改增全面推开为什么还叫试点
  • macos big sur值得升级吗
  • php连接数据库代码是什么
  • 保险公司的展业方式
  • php返回值
  • 一只华莱士飞蛙掠过森林地面 (© Stephen Dalton/Minden Pictures)
  • vue 父组件调用子组件效果
  • PHP中include/require/include_once/require_once使用心得
  • 残保金工资总额是计提还是实发
  • 增值税发票已经认证了,但是税票原票没给,会有什么后果
  • 端午节补几天工资
  • 金蝶软件资产负债表怎么生成
  • 自由会计师
  • 一次性发放年终奖金怎么扣除个人所得税144000有何意义
  • T-SQL语句修改数据表属性
  • 消费税在企业所得税前扣除吗
  • 报关期限是如何规定的
  • 房地产企业成本包括哪些
  • 法人向公司借款如何做账
  • 可供出售金融资产公允价值变动
  • 员工报销的话费要缴纳个税吗?
  • 清理固定资产是什么意思
  • 待认证进项税额是二级科目还是三级科目
  • 场地租赁费属于什么税收分类编码
  • 注册公司好麻烦
  • 五险一金是否需缴纳
  • 其他业务收入在资产负债表哪里体现
  • 本年利润怎么结账
  • 序时账是明细账吗
  • sqlserver 字符串包含
  • sql server数据库使用
  • mysql重置初始密码
  • 整理房间日记200
  • ,linux
  • windows8启动项设置
  • linux 怎么样
  • 滚小球的实验过程和材料
  • css 间距
  • unity3D游戏开发
  • javascript typeof id==='string'?document.getElementById(id):id解释 原创
  • javascript 触发事件列表 比较不错
  • js实现功能
  • jquery做下拉
  • JavaScript中的this
  • 重庆市医疗保障局
  • 北京国家税务网官网首页
  • 国家税务总局监控的重点税源纳税人的标准是
  • 京东开的店
  • 内蒙古国税局官网
  • 购车强制险包括哪些
  • 天津车辆购置税网上办税
  • 中关村税务所上班时间
  • 国家税务总局河南省税务干部学校
  • 2021年十大慈善企业
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设