位置: 编程技术 - 正文

JavaScript学习笔记之数组求和方法(javascript总结笔记)

编辑:rootadmin

推荐整理分享JavaScript学习笔记之数组求和方法(javascript总结笔记),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript总结笔记,javascript教程推荐知乎,javascript学习指南,javascript怎么学,javascript学习指南,javascript入门教程,javascript基础笔记,javascript基础笔记,内容如对您有帮助,希望把文章链接给更多的朋友!

推荐阅读:JavaScript学习笔记之数组的增、删、改、查

通过最近学习,越来越感觉JavaScript的强大与魅力之处,仅数组一个知识点就让我这样的初学者折腾了很久。折腾是折腾,但还是很有效果的,这几天的学习到的一些基本知识,就在自己的业务就用到了。顿感自信心爆棚,我也有一天能学会JavaScript。

别的不多说了,咱们今天一起来玩数组的求和,看看有哪些方法可以实现数组的求和。

数组方法

JavaScript中数组有很多种方法,下图能更好的向你阐述JavaScript有多少种方法,作用是啥:

简单点回顾一下前面学习的知识:

push():向数组末尾添加一个或多个元素

unshift(): 向数组的开头添加一个或多个元素

pop(): 删除数组最后一个元素

shift(): 删除数组第一个元素

sort(): 给数组排序

reverse(): 颠倒数组项在数组中的位置

concat(): 合并数组

slice(): 指定的位置开始删除指定的数组项,并且将删除的数组项构建成一个新数组

splice(): 对一个数组做删除、插入和替换

indexOf(): 从前向后查找元素在数组中位置

lastIndexOf(): 从后向前查找元素在数组中位置

forEach()、every()、some()、filter()和map():数组迭代

reduce(): 数组中的每个值(从左到右)开始合并,最终为一个值

reduceRight(): 数组中的每个值(从右到左)开始合并,最终为一个值

JavaScript学习笔记之数组求和方法(javascript总结笔记)

数组求和

今天的用例,假设我们有一个这样的数组:

需要将数组中的项值加起来0+1+2+3+4+5+6+7+8+9。我们应该怎么做,或者有哪些方法可以实现。简单的讲,就是想办法让数组项一个一个加起来。那是不是就要用到数组的迭代呢?是不是也可以借助这些方法实现数组的求和呢?

for循环和while循环

首先想到的就是这两种循环方法,这在上一节也尝试过了。再次??乱幌拢?/p>

再来换个while看看:

除了古老的for和while循环之外,在ES5中还新增加了其他的数组迭代方法,比如forEach()、every()、some()、filter()和map()等。而且这些方法都可以让数组中的每一个元素执行一次回调函数。如果一来,只需要对这个回调函数做一个数组项的累加功能:

forEach()方法

forEach()方法让数组每一项执行给定的回调函数callbackfn。这样,我们可以在回调函数getSum做一个累加计算。

some()方法

map()方法

filter()方法

every()方法

every()方法和前面几种方法略有不同,因为every()方法只有数组中每一项执行回调函数结果合部为true才会返回,不然就会返回false。因为在前面的回调函数中,需要增加return true;

reduce()和reduceRight()方法

reduce()和reduceRight()方法可以接受一个回调函数callbackfn作为累加器(accumulator),数组中的每个值(从左到右)开始合并,最终为一个值。这样也能让数组每个元素累加起来,达到数组求和的功能。

先创建一个累加器的回调函数:

同样以前面的数组为例:

前面测试,reduce()方法所费时间最短,本篇在测试似乎所费时间最长,不知道在哪出错了,还望有大神能指导迷津。reduceRight()方法和reduce()方法一样,只是他从数组的右边向左边累加。

总结

一个一个操作下来,数组的求和基本上通过数组遍历来实现,那么掌握了数组中各种遍历的方法,就能轻松的实现数组的求和。虽然这些遍历的方法能让实现数组的求和,但是不同的方法对性能有所不同。文章中的示例可能无法完全阐述他们性能方面的对比,如果您有更好的建议欢迎分享。

以上内容是针对JavaScript学习笔记之数组求和方法的全部介绍,希望对大家有所帮助!

JavaScript学习笔记之数组随机排序 推荐阅读:JavaScript学习笔记之数组求和方法JavaScript学习笔记之数组的增、删、改、查JavaScript中提供了sort()和reverse()方法对数组项重新排序。但很多时

JavaScript学习笔记之数组去重 推荐阅读:JavaScript学习笔记之数组的增、删、改、查JavaScript学习笔记之数组求和方法JavaScript学习笔记之数组随机排序话说面试常会碰到面试官会问JavaS

JavaScript学习笔记之取数组中最大值和最小值 推荐阅读:JavaScript学习笔记之数组的增、删、改、查JavaScript学习笔记之数组求和方法JavaScript学习笔记之数组随机排序在实际业务中有的时候要取出数

标签: javascript总结笔记

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

上一篇:JavaScript学习笔记之数组的增、删、改、查(javascript教程完整版)

下一篇:JavaScript学习笔记之数组随机排序(javascript教程完整版)

  • 累进税率的形式有全额累进税率和什么两种
  • 增值税税负税率
  • 赞助支出和广告支出的区别
  • 银行本票与银行本票存款的区别
  • 外币实收资本入账汇率
  • 发票没交税可以退税吗
  • 个税申报时提示扣缴单位无有效的税费种认定信息
  • 股权转让1元转让
  • 企业收到的土地补偿款的企业所得税
  • 债务重组损失是费用吗
  • 收到招聘通知
  • 免税销售额是否计入成本
  • 新成立的分公司怎么样
  • 美国边境管理体制
  • 农村合作社收到奖金分录
  • 以前年度多做了收入怎样调账
  • 分期收款什么时候交税
  • 中小企业划分标准
  • 1697508513
  • 工资中的公积金怎么算法
  • 出纳有哪些清点项目
  • compaq-rba.exe是哪个方面的进程 作用是什么 compaq-rba进程查询
  • php string函数
  • window10黑白模式
  • 存货损失的会计分录
  • 出口收汇可以收人民币吗
  • fsck是什么文件
  • yii实现使用CUploadedFile上传文件的方法
  • 政府搬迁补偿款怎么算
  • vue播放rtsp视频流
  • 税务局开出来的发票没问题吧?
  • 长期借款的
  • 维修费成本怎么结转
  • 猿创征文,宝藏工具篇
  • 喰种小说在线阅读
  • 面试题集锦
  • 用人单位招用失业人员补贴
  • 管家婆软件出库入库如何用
  • 固定资产售后回购会计处理
  • 2020年小规模纳税人增值税政策
  • sql server 2008数据库文件
  • 公司发行可转债是利好还是利空
  • 应收账款属于什么会计要素
  • 主营业务成本大于主营业务收入怎么办
  • 收到银行回单如何打印
  • 社保月费基数
  • 企业内部股权转让协议书
  • 收到非税收入一般缴款书怎么分录
  • 新税法实施后以前的条例规章作废吗
  • 进项税包含
  • 现金流量表的编制基础是权责发生制
  • 管理费用是负数影响利润表吗
  • 原始凭证分割单怎么填写
  • 用SELECT... INTO OUTFILE语句导出MySQL数据的教程
  • cmd shutdown命令
  • 苹果15手机价格和图片颜色
  • win7自动变成win10
  • win10 9月更新 问题
  • windows key查询
  • Windows Server 2008中安装DNS服务器详细图文教程
  • 操作系统安装日期查看
  • linux 压缩包zip
  • WIN10补丁无法卸载
  • win7系统的桌面图标怎么调出来
  • win7麦克风不好使
  • asm指令
  • nodejs 程序 打包服务端
  • 彻底弄懂js中的this指向
  • 服务器总是自动关机
  • vue如何用
  • pythonjam怎么用
  • javascript操作数组的方法
  • javascript运用
  • 江苏电子税务局网站官网
  • 下载重庆税务官方app
  • 江西省企业社会保险费缴费指南
  • 延安市地方税务局电话
  • 主要领导负责人
  • 工本费每月都扣?
  • 税务申报按季度申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设