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

  • 华硕笔记本15.6英寸多大(华硕15 6寸笔记本)(华硕笔记本15.6寸是什么型号)

    华硕笔记本15.6英寸多大(华硕15 6寸笔记本)(华硕笔记本15.6寸是什么型号)

  • iphone怎么限制别人连热点(苹果怎么限制别人用自己wifi的速度)

    iphone怎么限制别人连热点(苹果怎么限制别人用自己wifi的速度)

  • 微信公众号头像模糊怎么办(微信公众号头像暂时无法查看)

    微信公众号头像模糊怎么办(微信公众号头像暂时无法查看)

  • ios13值得升级吗(ios13值得升级14吗)

    ios13值得升级吗(ios13值得升级14吗)

  • 荣耀20pro能开空调吗(荣耀20手机可以开空调吗无设置?)

    荣耀20pro能开空调吗(荣耀20手机可以开空调吗无设置?)

  • 华为荣耀v30黑白模式怎么关闭(华为荣耀v30黑白屏怎么办)

    华为荣耀v30黑白模式怎么关闭(华为荣耀v30黑白屏怎么办)

  • 无人机分类(无人机分类等级)

    无人机分类(无人机分类等级)

  • 光敏电阻的工作原理(光敏电阻的工作原理和光电效应的异同点)

    光敏电阻的工作原理(光敏电阻的工作原理和光电效应的异同点)

  • 未激活的苹果手机怎么查序列号(未激活的苹果手机怎么关机)

    未激活的苹果手机怎么查序列号(未激活的苹果手机怎么关机)

  • 苹果xs怎么分屏(苹果手机xs如何分屏操作)

    苹果xs怎么分屏(苹果手机xs如何分屏操作)

  • 小爱mini连不上wifi为什么(小爱mini连不上网)

    小爱mini连不上wifi为什么(小爱mini连不上网)

  • 荣耀note8是多少寸的呀(荣耀note8有多大)

    荣耀note8是多少寸的呀(荣耀note8有多大)

  • designedbyvivo是啥型号(designed by vivo是什么意思)

    designedbyvivo是啥型号(designed by vivo是什么意思)

  • x23和x23幻彩版手机壳通用吗(x23和x23幻彩版手机怎么区分)

    x23和x23幻彩版手机壳通用吗(x23和x23幻彩版手机怎么区分)

  • ipad死机打不开(ipad卡死重启开不了)

    ipad死机打不开(ipad卡死重启开不了)

  • 苹果手机系统怎么升级(苹果手机系统怎么读)

    苹果手机系统怎么升级(苹果手机系统怎么读)

  • 系统固件是什么(固件版本和系统版本)

    系统固件是什么(固件版本和系统版本)

  • 怎样设置页脚(怎样设置页脚日期的格式)

    怎样设置页脚(怎样设置页脚日期的格式)

  • 怎么更新ios13系统(怎么更新ios13.0)

    怎么更新ios13系统(怎么更新ios13.0)

  • 哈罗出行怎么付钱(哈罗出行付了钱,我能取消订单嘛)

    哈罗出行怎么付钱(哈罗出行付了钱,我能取消订单嘛)

  • JEECG微服务架构配置和运行(微服务架构java框架)

    JEECG微服务架构配置和运行(微服务架构java框架)

  • 学习CSS3,模拟春雪漫天飘的动画效果(css3的模块结构和应用)

    学习CSS3,模拟春雪漫天飘的动画效果(css3的模块结构和应用)

  • sosreport命令  收集并打包诊断和支持数据(sosreport命令收集详细信息)

    sosreport命令 收集并打包诊断和支持数据(sosreport命令收集详细信息)

  • DEDECMS不规则的列表实现方法 每隔5行加一虚线(div不规则排版)

    DEDECMS不规则的列表实现方法 每隔5行加一虚线(div不规则排版)

  • 取得投资款属于什么过程
  • 劳务合同印花税税目
  • 城建税及教育费附加怎么计算
  • 收到货款没开票做应收还还应付
  • 库存商品属于资产类会计科目吗
  • 增值税抵扣不够怎么解决
  • 手撕票几个点
  • 残值要不要做分录
  • 新企业需要结转增值税吗
  • 合同能源管理项目账务处理
  • 普通发票辨别真伪
  • 私募基金超募如何购买
  • 什么发票可以冲销
  • 企业合并的被合并方会计分录
  • 然后销售产品
  • 销售退回跨年所得税如何做账?
  • 上月未申报纳税补申报怎么做不会有罚款吗?
  • 个人所得税反推器
  • 通讯费税前扣除填报怎么填
  • 2020年小规模生活服务业优惠政策
  • 残障人士能享受的税收优惠
  • 其他权益工具包含
  • 社保基数每个月可以调整一次吗
  • 劳务外包收入公式是什么
  • 苹果mac dns设置
  • 企业收到政府补助时,无需开发票,双方根据银行电汇单
  • commandlineoptionsyntaxerror翻译详情
  • linux 中cat
  • 去年的记账凭证错了怎么办
  • 预付账款补付货款分录
  • php 输出
  • 会计差错更正处理
  • 企业购入固定资产,价值3000元,误记入管理费用账户
  • PHP:curl_multi_remove_handle()的用法_cURL函数
  • 分公司不纳入合并
  • php怎么定义全局变量
  • 填制的凭证内容有哪些
  • 材料委托加工
  • 总分类账户原材料
  • 废旧物资回收经营单位
  • vue ts
  • php的中文名
  • 【C#+JavaScript+SQL Server】实现Web端在线考试系统 五:考试模块设计(附源码和资源)
  • 哪一款macbook
  • 工会收到单位拨款的会计分录
  • 跨境电商小规模怎么做账报税
  • python字典遍历key
  • phpcms模板下载
  • 施工企业的内部往来
  • 小规模纳税人的个人所得税怎么算
  • 固定资产货币化,货币资产保险化,保险资产信托化
  • 金融商品转让和贷款服务
  • 个税中的免税收入都包括什么
  • 公账取现用途写什么
  • sql随机抽取
  • 经营活动现金流量净额是什么意思
  • 营业利润是负数什么原因
  • 电梯安装费如何分摊
  • 记账联是哪一联
  • 出纳账户怎么设置
  • 会计从业资格证取消了吗
  • mac系统10.10
  • 安装centos图形界面
  • win10周年更新版是什么意思
  • win8和win10双系统切换
  • node链接数据库
  • 安卓沉浸式状态栏框架
  • Bullet(Cocos2dx)之交叉编译Android,集成到cocos2dx3.x
  • 查看linux中某个端口(port)是否被占用的方法
  • 阿里大于短信验证接口
  • 能用javascript 最终
  • linux jhat
  • mysql里多表查询语句怎么写
  • 陷阱类过关游戏
  • 浅谈python 四种数值类型(int,long,float,complex)
  • 医保电子缴费凭证怎么查询
  • 湖北省地税局稽查局
  • 国税地税发票编码查询
  • 深圳纳税信息查询
  • 兰州税收优惠园在哪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设