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

  • 12pro和12 pro max处理器区别(12pro和12 pro max区别)(12pro和12 pro max处理器区别)

    12pro和12 pro max处理器区别(12pro和12 pro max区别)(12pro和12 pro max处理器区别)

  • 美团订酒店怎么订(美团订酒店怎么代付)

    美团订酒店怎么订(美团订酒店怎么代付)

  • 猫眼电影票砍价一般需要多少人(猫眼电影砍价成功后是一张票使用优惠券吗)

    猫眼电影票砍价一般需要多少人(猫眼电影砍价成功后是一张票使用优惠券吗)

  • 哔哩哔哩概念版啥区别(哔哩哔哩概念版旧版)

    哔哩哔哩概念版啥区别(哔哩哔哩概念版旧版)

  • 戴尔强制重启快捷键(戴尔如何强制重启)

    戴尔强制重启快捷键(戴尔如何强制重启)

  • 不开通拼多多电子面单可以吗(不开通拼多多电子面单怎么打单)

    不开通拼多多电子面单可以吗(不开通拼多多电子面单怎么打单)

  • 手机qq为什么打开又秒退了(手机qq为什么打不开腾讯文档)

    手机qq为什么打开又秒退了(手机qq为什么打不开腾讯文档)

  • ipad pro什么时候上市的(iPad pro什么时候更新)

    ipad pro什么时候上市的(iPad pro什么时候更新)

  • 话放和声卡有什么区别(话放 声卡)

    话放和声卡有什么区别(话放 声卡)

  • 小米8手机音量自动变大(小米8手机音量键老是自己调高怎么办)

    小米8手机音量自动变大(小米8手机音量键老是自己调高怎么办)

  • ppt无法全屏放映(ppt2016播放不能全屏)

    ppt无法全屏放映(ppt2016播放不能全屏)

  • 手机能连上wifi但上不了网(手机能连上wifi天猫精灵连不上)

    手机能连上wifi但上不了网(手机能连上wifi天猫精灵连不上)

  • 网络通信出现问题是怎么回事(网络通信出现问题怎么解决苹果手机)

    网络通信出现问题是怎么回事(网络通信出现问题怎么解决苹果手机)

  • 抖音一共几个版本(抖音有多少个版本)

    抖音一共几个版本(抖音有多少个版本)

  • qq号查找和精确查找的区别(qq号查找和精确查找是什么意思)

    qq号查找和精确查找的区别(qq号查找和精确查找是什么意思)

  • 小米2016112什么型号(小米2016201)

    小米2016112什么型号(小米2016201)

  • 手机令牌有什么作用(手机令牌什么原理)

    手机令牌有什么作用(手机令牌什么原理)

  • 苹果11可以用18w快充吗(苹果11可以用18w快充吗,对电池好吗)

    苹果11可以用18w快充吗(苹果11可以用18w快充吗,对电池好吗)

  • 什么叫增强短信(增强短信什么意思)

    什么叫增强短信(增强短信什么意思)

  • 淘宝账户已被保护如何解除(淘宝账户已被保护还能解除吗)

    淘宝账户已被保护如何解除(淘宝账户已被保护还能解除吗)

  • 相互保可以保多少种疾病(相互保有上限吗)

    相互保可以保多少种疾病(相互保有上限吗)

  • 电话加入黑名单会怎样(电话加入黑名单对方还能打通吗)

    电话加入黑名单会怎样(电话加入黑名单对方还能打通吗)

  • 如何更换win 7开机声音?(win7如何更换开机密码)

    如何更换win 7开机声音?(win7如何更换开机密码)

  • 城建税减免性质代码怎么选择2020年4月
  • 销售收入怎么计算销项税额
  • 移动怎么开当月发票
  • 租赁设备损毁赔偿案例
  • 税盘减免主表不显示减免怎么填
  • 金税盘一年
  • 企业固定资产折旧当月增加当月计提吗
  • 加工样品全流程总结
  • 应收账款贷方余额表示什么
  • 自建厂房可以不办理房产证吗
  • 企业临时账户是什么意思
  • 月底结转应交税费怎么弄
  • 董事费如何计算个人所得税
  • 打印出来的明细账怎么装订
  • 企业所得税季度预缴
  • 理财赎回本金没赎回利息咋办
  • 回收站已损坏 是否清空该驱动,点鼠标无法操作
  • 连续亏损的公司还要去吗
  • 公司运输车辆加油会计分录
  • mac电脑command+s
  • kb4499164安装失败怎么办
  • 无产权买卖
  • 代发工资跨行手续怎么办
  • redis网络模型 框架图
  • PHP:proc_terminate()的用法_命令行函数
  • 坏账减值准备账务处理
  • 跨年的材料票可以抵扣吗
  • 在生产经营过程中违反什么规定
  • 企业重组特殊性税务处理计税基础
  • 基于javaweb是什么意思
  • 云服务器可以一直开着吗
  • 金蝶利息收入结转怎么弄
  • 应交增值税减免税额怎么结转
  • 出口退税备案是代理的需要主办会计身份证复印件吗
  • 收押金退押金会计分录
  • phpcms教程
  • 发票税金计入什么会计科目
  • 香港公司代收国际汇款税务怎么处理
  • 个税汇算清缴时劳务报酬怎么计税
  • 加计扣除产生的利润可以分配吗
  • 餐费开增值税专用发票
  • 开具的简易计税凭证
  • 所得税汇算清缴前取得跨年发票
  • 利息资本化的利弊
  • 合并报表编制方法有几种
  • 公司赠送客户礼品怎么做账
  • sqlserver获取当天零点时间
  • 数据库 mysql
  • Windows Server 2008制作密码重设盘
  • ubuntu怎么切换桌面
  • linux操作系统百度百科
  • 安装win8系统需要什么条件
  • win7系统怎么重置网络
  • ubuntu安装音乐软件
  • ubuntu下软件
  • linux远程登录命令ssh
  • sqlmangr.exe - sqlmangr是什么进程 有什么用
  • linux 操作系统
  • linux里面怎么截屏
  • win10专业版装不上m1136驱动
  • 怎样解决windows照片查看器无法显示此图片
  • w8虚拟内存怎么设置
  • cocos2d安装
  • node.js获取文件信息的方法是什么
  • perl hex
  • cocos3.0
  • jquery焦点
  • 仿京东首页html5
  • 网页上面的收藏夹显示
  • angularjs时间控件
  • js正则表达式验证姓名
  • 整理的什么
  • checkbox选中一个其余选项置灰
  • 朵朵舞百科
  • 税务系统会议费管理办法
  • 湖北税务投诉电话
  • 职工教育经费可以结转吗
  • 社保已经申报成功未缴费在哪交费
  • 小规模企业开通税务几天生效啊
  • 安徽增值税普通发票税率1%
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设