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

  • 支付宝双v会员怎么取消自动续费(支付宝双v会员值得买吗)

    支付宝双v会员怎么取消自动续费(支付宝双v会员值得买吗)

  • 网易云音乐听歌排行怎么删(网易云音乐听歌排行怎么删除)

    网易云音乐听歌排行怎么删(网易云音乐听歌排行怎么删除)

  • 宽带和路由器一样吗(宽带和路由器一体的好还是分开好)

    宽带和路由器一样吗(宽带和路由器一体的好还是分开好)

  • 快手带货需要什么条件(快手带货需要什么证件)

    快手带货需要什么条件(快手带货需要什么证件)

  • ipad看电视看一会黑屏(ipad2021看电视)

    ipad看电视看一会黑屏(ipad2021看电视)

  • 路由器用了6年了有什么影响(路由器用了6年了要换吗)

    路由器用了6年了有什么影响(路由器用了6年了要换吗)

  • 投诉卖家不撤销会怎样(不撤销投诉 卖家就不发货)

    投诉卖家不撤销会怎样(不撤销投诉 卖家就不发货)

  • AirPods耳机三星能用吗(airpods适配三星吗)

    AirPods耳机三星能用吗(airpods适配三星吗)

  • 小米怎么退出安全模式(小米怎么退出安全模式手机)

    小米怎么退出安全模式(小米怎么退出安全模式手机)

  • 苹果数据volte是什么意思(苹果手机 volte)

    苹果数据volte是什么意思(苹果手机 volte)

  • 计算机硬件系统主要有(计算机硬件系统分为哪五个基本的部分)

    计算机硬件系统主要有(计算机硬件系统分为哪五个基本的部分)

  • 淘宝补发后怎么付钱(淘宝补发怎么看)

    淘宝补发后怎么付钱(淘宝补发怎么看)

  • 手机白名单怎么设置(手机白名单怎么取消)

    手机白名单怎么设置(手机白名单怎么取消)

  • 小米nfc怎么给公交卡充值(小米nfc怎么公交卡充值)

    小米nfc怎么给公交卡充值(小米nfc怎么公交卡充值)

  • 苹果6有nfc在哪里设置(苹果6手机有没有nfc功能设置)

    苹果6有nfc在哪里设置(苹果6手机有没有nfc功能设置)

  • 苹果lcd和oled的区别(苹果lcd和oled对比视频)

    苹果lcd和oled的区别(苹果lcd和oled对比视频)

  • 京东拼购店红包怎么用(京东拼购店红包怎么使用)

    京东拼购店红包怎么用(京东拼购店红包怎么使用)

  • 监控怎么设置保存30天(监控怎么设置保留一个月)

    监控怎么设置保存30天(监控怎么设置保留一个月)

  • 同程艺龙vip春运抢票卡怎么退(同程艺龙最迟多久出票)

    同程艺龙vip春运抢票卡怎么退(同程艺龙最迟多久出票)

  • 不是常用的图像文件格式是哪一个(不是常用的图像文件格式有哪些)

    不是常用的图像文件格式是哪一个(不是常用的图像文件格式有哪些)

  • 华为p30pro微信视频怎么开启(华为p30pro微信视频录屏怎么能录到声音)

    华为p30pro微信视频怎么开启(华为p30pro微信视频录屏怎么能录到声音)

  • cad怎么画点绘制点(cad如何绘点)

    cad怎么画点绘制点(cad如何绘点)

  • Word如何制作海报(word如何制作海报背景图片)

    Word如何制作海报(word如何制作海报背景图片)

  • ps蒙版反向快捷键(ps2020反向蒙版)

    ps蒙版反向快捷键(ps2020反向蒙版)

  • React Hook - useState函数的详细解析

    React Hook - useState函数的详细解析

  • 混合销售行为的基本特征不包括
  • 一般纳税人什么情况可以开3%的发票
  • 成品油认证后要开票怎么做
  • 开办药品企业的要求
  • 没有工会 还需要交钱吗
  • 外出经营能自带食物吗
  • 信息技术服务企业研发费用加计扣除
  • 原材料什么时候结转成本
  • 营业外收入交税会计分录
  • 水果 增值税专票
  • 二手房增值营业税
  • 申报文化事业建设费
  • 金税盘管理费用怎么结转
  • 专票开户行和账号必须填吗
  • 小型微利企业所得税减免政策
  • 建筑业异地预缴增值税
  • 报废固定资产收入计入什么科目
  • 完工百分比法确认成本 分录
  • 贴现扣的钱叫什么
  • 金蝶标准版年末已经结账如果重新结账
  • 有质量问题的产品案例
  • 公司房租押金收不回来账务处理
  • 支付装修款
  • 缴纳残保金和工龄有关吗
  • 开具的电子发票需要打印出来做账吗
  • 小规模纳税人买车可以抵税吗
  • 资产处置收益期末有余额吗
  • 绿萝可以放卧室吗晚上睡觉对人害吗
  • kms.exe
  • 多交税款的退还
  • 划转国有划拨土地流程
  • 企业所得税计算器在线计算
  • 将自产的应税消费品用于连续生产应税消费品
  • 收到预付货款下月交货会计分录
  • 登录界面html5
  • php aes加密解密
  • 基本数据结构包括哪些
  • 财务软件服务合同要交印花税吗
  • 跨年的增值税专票怎么开
  • 还贷款的卡有利息吗
  • 材料采购会计科目怎么使用
  • wordpress怎么安装插件
  • 实行核定征收印花税
  • 建筑附加税税率
  • 纳税申报相关操作有哪些
  • 以前年度税费减免税
  • 出口的进项发票认证后要确认吗
  • 不验资实收资本怎么做账
  • 公司注销应付账款要为零吗
  • 固定资产转为投资性房地产的账务处理公允价值
  • 进项和销项税月底有余额吗
  • 累计摊销可以做什么分录
  • 搭赠商品如何开票
  • Ubuntu下MySQL及工具安装配置详解
  • mac所有窗口最小化
  • 安装操作系统win10
  • rundll32.exe是什么程序
  • winxp系统用户不见了
  • win8如何开启蓝牙
  • centos搭建v2
  • kpupgrader.exe是什么
  • windows7一键还原在哪
  • pax是什么文件
  • win7系统开机
  • 你会支持国产系统吗英文
  • win8系统安装的软件在哪里
  • opengl教程48讲
  • 给自己的网站制作软件
  • node.js安装模式选择
  • 详解使用Visual Studio Code对Node.js进行断点调试
  • unity-chan
  • Unity3D游戏开发pdf
  • python抓取整站链接
  • 电商平台税收怎么交
  • 政府免费
  • 印花税当期没有发生可以不用申报吗
  • 汽车销售流程有哪些环节?每个环节的主要内容是什么?
  • 单据整理方法
  • 税务局残疾人就业保障金
  • 食品烟酒消费包括哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设