位置: 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)

  • 韶音耳机怎么重新配对(韶音耳机怎么重新配对新手机)

    韶音耳机怎么重新配对(韶音耳机怎么重新配对新手机)

  • 如何删除手机银行转账记录(如何删除手机银行卡号)

    如何删除手机银行转账记录(如何删除手机银行卡号)

  • 苹果手机通讯记录只保存一周(苹果手机通讯记录怎么查询以前的)

    苹果手机通讯记录只保存一周(苹果手机通讯记录怎么查询以前的)

  • 苹果手机冒号怎么打(苹果手机冒号怎样打出来)

    苹果手机冒号怎么打(苹果手机冒号怎样打出来)

  • 为什么tinder图片加载不出来(ppp产业基金是什么)

    为什么tinder图片加载不出来(ppp产业基金是什么)

  • 电脑屏幕截图三个键(电脑屏幕截图三个键局部)

    电脑屏幕截图三个键(电脑屏幕截图三个键局部)

  • 苹果手机怎么看抖音访客记录(苹果手机怎么看小电影)

    苹果手机怎么看抖音访客记录(苹果手机怎么看小电影)

  • qq标识怎么恢复(qq标识如何恢复)

    qq标识怎么恢复(qq标识如何恢复)

  • 微信上面有个正在浏览(微信上面有个正方形怎么调出来)

    微信上面有个正在浏览(微信上面有个正方形怎么调出来)

  • 怎么减少cpu耗电(怎么减低cpu)

    怎么减少cpu耗电(怎么减低cpu)

  • 纤纤影视怎么打不开了

    纤纤影视怎么打不开了

  • 淘宝未收到货怎么申请退款流程(淘宝未收到货怎样投诉商家)

    淘宝未收到货怎么申请退款流程(淘宝未收到货怎样投诉商家)

  • 爱奇艺怎么投放广告(爱奇艺怎么投放到电视上)

    爱奇艺怎么投放广告(爱奇艺怎么投放到电视上)

  • 两个excel表格合并(两个Excel表格合并)

    两个excel表格合并(两个Excel表格合并)

  • 移动卡显示hd怎么消除(移动卡显示hd啥意思)

    移动卡显示hd怎么消除(移动卡显示hd啥意思)

  • 2019qq群名片在哪(qq里的群名片是什么)

    2019qq群名片在哪(qq里的群名片是什么)

  • 淘宝预售能修改地址吗(淘宝预售修改地址可以修改几次)

    淘宝预售能修改地址吗(淘宝预售修改地址可以修改几次)

  • iphonexsmax有耳机孔吗(iphonexsmax有耳机转换器吗)

    iphonexsmax有耳机孔吗(iphonexsmax有耳机转换器吗)

  • 苹果11是不是高通基带(苹果11是不是高清屏幕)

    苹果11是不是高通基带(苹果11是不是高清屏幕)

  • 小米mix3支持40w快充吗(小米mix3支持5g吗)

    小米mix3支持40w快充吗(小米mix3支持5g吗)

  • 苹果x指纹设置(苹果x的指纹解锁)

    苹果x指纹设置(苹果x的指纹解锁)

  • 苹果7防误触模式在哪(苹果防误触模式在哪里)

    苹果7防误触模式在哪(苹果防误触模式在哪里)

  • word字间距不一致(word文档字间距不一样怎么调)

    word字间距不一致(word文档字间距不一样怎么调)

  • 快影如何去掉原声(快影如何去掉原字幕)

    快影如何去掉原声(快影如何去掉原字幕)

  • 手机照片上怎么加字(手机照片上怎么画红圈)

    手机照片上怎么加字(手机照片上怎么画红圈)

  • 电脑cpu性能天梯图2022最新高清大图(电脑CPU性能天梯)

    电脑cpu性能天梯图2022最新高清大图(电脑CPU性能天梯)

  • Lesson 10.1 超参数优化与枚举网格的理论极限和随机网格搜索 RandomSearchCV(超参数及其作用)

    Lesson 10.1 超参数优化与枚举网格的理论极限和随机网格搜索 RandomSearchCV(超参数及其作用)

  • 织梦DEDECMS搜索提交用a便签替换button标签方法(织梦cms怎么样)

    织梦DEDECMS搜索提交用a便签替换button标签方法(织梦cms怎么样)

  • 织梦dede专题不同节点不能选取同样文章的解决方法(织梦专题页模板)

    织梦dede专题不同节点不能选取同样文章的解决方法(织梦专题页模板)

  • 新公司第一年要做亏
  • 车船税保险公司会不会多收
  • 合同成本在哪个科目列支
  • 固定资产折旧购买日期还是使用日期呢
  • 企业不开票的收入会怎么样处理
  • 手工发票有没有期限
  • 担保费和评审费计入什么科目
  • 小微企业的认定标准2021
  • 外出拓展训练活动所花的费用怎么做分录?
  • 应付股东款可以结转实收资本吗
  • 对方承担税点的发票额怎么计算
  • 虚开发票走账对方不返还如何处理?
  • 会计报表的附表包括哪些
  • 未结转损益可以结账吗
  • 新注册的公司什么时候可以开票纳税
  • 国税实名认证一般是公司里谁去认证的
  • 小规模纳税人收入账务处理
  • 国有企业的所得税怎么算
  • 公司抵扣发票不用交税吗
  • 营改增后税金由哪几项费用组成
  • 建筑业小规模纳税人异地开票
  • 应对税务稽查的六点注意事项
  • 微信认证服务费可以开发票吗
  • 未取得房产证的房子如何迁户口
  • 收到带息商业票据贴现会计处理
  • 员工两处取得工资收入
  • 投资长期溢价债券,容易获取投资收益
  • 所得税贷款利息扣除
  • php跨域解决方案
  • f12开发者工具调试打不开
  • phpstudy访问数据库
  • 专项应付款转资本公积需要什么附件
  • 所得税申报表应怎么填
  • 季度申报残保金怎么计算
  • css定位属性的运用
  • php判断链表是否有环
  • 专项应付款怎么转固定资产
  • 销售房产收取预算费用
  • 帝国cms自动推送插件
  • 外资公司股东
  • mongodb aggregate 性能
  • 企业所得税汇算清缴表
  • 一般纳税人之间转让土地使用权交哪些税金
  • 个税代扣代缴手续费返还需要缴纳增值税吗
  • 承兑汇票上能手写名字吗
  • 什么叫金税四期呢?
  • 纳税人办理普通发票流程
  • 对公账户收到钱都要开票吗
  • 冲以前年度成本分路
  • 外出经营一定要开
  • 企业哪些税费不通过应交税费账户进行核算
  • 会计事务所给的发票
  • win2003和xp一样吗
  • debian系列
  • linux常用小技巧
  • centos挂载点
  • upromise0.exe - upromise0进程是什么文件
  • win7回收站路径在哪里
  • win8应用程序无法正常启动
  • xp系统如何添加启动项
  • ubuntu20.04安装配置
  • mac上如何卸载软件
  • linux用户账户管理
  • quickres.exe - quickres是什么进程 作用是什么
  • 升级win8系统
  • 索引位置怎么是c盘?
  • windows 8 key
  • [置顶]电影名字《收件人不详》
  • android基于什么语言
  • js响应式布局
  • matplotlib pypi
  • MVC Ajax Helper或Jquery异步加载部分视图
  • dota2 服务器ip地址
  • Express + Session 实现登录验证功能
  • jquery自动点击按钮
  • 门诊看病记录怎么查
  • 重庆国税电子税务局手机版
  • 税务暂停办理业务通知
  • 消费税申报流程图
  • 2023年河北居民养老保险缴费时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设