位置: 编程技术 - 正文

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教程完整版)

  • 印花税计算是含增值税吗
  • 技术服务的分录
  • 实缴资本需要存放多久
  • 预收账款借方和贷方表示什么
  • 进出口企业外汇收支平衡
  • 资产处理损益属于什么科目借贷方向
  • 购置新建商品房,自房屋交付使用
  • 税务评估补税如何入账处理合适?
  • 税务征收与管理
  • 进项不够怎么避税
  • 劳务建筑公司一年可以赚多少
  • 土地使用税每年都交还是交一次
  • 2016年营改增后购买氧气乙炔税率是多少
  • 存根联和记账联丢失有影响吗
  • 购买固定资产的税率是多少
  • 金税盘抄税报税清卡流程图
  • 高新技术企业资格复核
  • 申报个税是按哪个月的工资表
  • 坏账收回的会计处理方法
  • 合同印花税交给谁
  • 免费样品费计入什么科目
  • 水利基金退税怎么做会计分录
  • 推广费开票属于什么费用
  • 房地产资质代理公司排名
  • 收到客户预付的货款的会计分录
  • linux特殊权限设置
  • 进入苹果icloud
  • 定金签合同能退吗
  • linux动态扩容
  • php cgi
  • wordpress简码怎么用
  • 商业零售企业存货非正常损失
  • 威斯康星州1976
  • 股权转让怎么做帐务处理
  • 无形资产租金计入什么会计科目里
  • zend框架教程
  • php 替换
  • 打造出ChatGPT的,是怎样一群人?
  • 公司为员工代扣代缴
  • 出差补贴要扣税吗
  • 天猫如何不走对公账户
  • php命令行模式
  • 公司个人借款如何做账
  • 详解中国航天三垂一远
  • 人工费用计入
  • 平行结转分步法各步骤的费用
  • 房屋出租后转租缴纳房产税吗
  • 以前年度损益的科目代码
  • 营业外支出属于费用类科目吗
  • 扶贫小额信贷分贷统还违规吗
  • 加油站汽油损耗分析
  • 无形资产入股交税吗
  • 建账的注意事项
  • SQL Server 2012 sa用户登录错误18456的解决方法
  • xp系统cmd怎么打开
  • mysql通过my.cnf修改默认字符集为utf-8的方法和注意事项
  • 阿里云centos7安装图形界面
  • porteus中文版下载
  • mac book丢失
  • Mac通过AppleID登录窗口
  • 如何让win8系统变快
  • win7如何录制电脑屏幕
  • 听歌播放失败什么意思
  • win7 64位旗舰版下载后怎样禁用搜索记录?win7禁用搜索记录的设置方法
  • window10添加虚拟网卡
  • WIN10系统安装教程
  • win10的uwp在哪
  • Win10预览版拆弹
  • 在对linux系统中dir
  • jquery弹出页面
  • js正则匹配特殊符号
  • js响应鼠标点击不了
  • Embedded statement cannot be a declaration or labeled statement
  • 云税票管家是什么软件
  • 成都暖气费补贴
  • 江苏省税务局电子发票
  • 广告行业税率6%包含的内容
  • 江苏税务缴费小程序
  • 财税方面的问题有什么
  • 新版零申报印花税怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设