分享JS的一些优雅写法(reduce/map)

本篇文章给大家带来了关于js的相关知识,其中主要给大家介绍了js的一些优雅写法,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。

分享JS的一些优雅写法(reduce/map)

JS的一些优雅写法

reduce

1、可以使用 reduce 方法来实现对象数组中根据某一key值求和

例如,假设有以下对象数组:

法语写作助手 法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

法语写作助手 31 查看详情 法语写作助手

const arr = [  { name: 'apple', price: 2 },  { name: 'banana', price: 3 },  { name: 'orange', price: 4 },];

如果要根据price属性求和,可以使用以下代码:

const sum = arr.reduce((acc, cur) => acc + cur.price, 0);console.log(sum); // 9

72f01be4547b69fc88e905304e86a88.png

其中,reduce方法的第一个参数是一个回调函数,它接收两个参数:累加器(acc)和当前元素(cur)。回调函数的返回值会作为下一次调用回调函数时的累加器的值。reduce方法的第二个参数是累加器的初始值,这里设置为0。

在回调函数中,我们将累加器和当前元素的price属性相加,最终得到了所有元素的price属性的总和。

map

1、可以使用map方法来实现对象数组中根据某一key值,取得另外一个key的值。

例如,假设有以下对象数组:

const arr = [  { name: 'apple', price: 2 },  { name: 'banana', price: 3 },  { name: 'orange', price: 4 },];

如果要根据name属性获取price属性,可以使用以下代码:

const prices = arr.map(item => item.name === 'banana' ? item.price : null);console.log(prices); // [null, 3, null]

7c2c700d0548841f09b98a81c67eef3.png

其中,map方法的参数是一个回调函数,它接收一个参数:当前元素(item)。回调函数的返回值会作为新数组的元素。在回调函数中,我们判断当前元素的name属性是否等于’banana’,如果是,则返回当前元素的price属性,否则返回null。最终得到了一个新数组,其中只有name属性为’banana’的元素的price属性有值,其他元素的price属性为null。

2、可以使用map方法来获取对象数组中根据某一key值得到的元素的price属性,可以使用find方法来实现。

例如,假设有以下对象数组:

const arr = [  { name: 'apple', price: 2 },  { name: 'banana', price: 3 },  { name: 'orange', price: 4 },];

如果要根据name属性获取price属性,可以使用以下代码:

const banana = arr.find(item => item.name === 'banana');if (banana) {  console.log(banana.price); // 3}复制代码

e5437e021fcc9158d3c5cd78482af0d.png

其中,find方法的参数是一个回调函数,它接收一个参数:当前元素(item)。回调函数需要返回一个布尔值,表示当前元素是否符合条件。find方法会返回符合条件的第一个元素,如果没有符合条件的元素,则返回undefined。

在回调函数中,我们判断当前元素是否banana,如果是,则返回当前元素。最终得到了一个对象,其中只有name属性为’banana’的元素的price属性有值,其他元素price属性为undefined。我们可以使用if语句来判断是否找到了符合条件的元素,如果找到了,则输出它的price属性。

推荐学习:《JavaScript视频教程》

以上就是分享JS的一些优雅写法(reduce/map)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/542410.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 15:53:29
下一篇 2025年11月9日 15:54:38

相关推荐

  • 如何在Golang中实现任务列表拖拽功能

    Golang不直接实现拖拽,而是通过API支持前端拖拽功能。前端使用HTML5或SortableJS实现任务项拖动,用户调整顺序后,JavaScript将新顺序(如[2, 1])通过POST请求发送至Golang后端。后端定义/api/reorder接口,接收包含任务ID数组的JSON数据,遍历并更…

    2025年12月16日
    000
  • 如何在Golang中开发小型CRM系统

    先定义客户结构体并实现REST API,再通过net/http搭建路由,结合SQLite完成增删改查。1. 设计Customer结构体包含ID、Name、Email等字段;2. 使用net/http创建GET/POST/PUT/DELETE路由处理请求;3. 用database/sql和mattn/…

    2025年12月16日
    000
  • 如何在Golang中构建微型电商项目

    答案:微型电商项目可通过Gin框架快速搭建,合理划分模块实现核心功能。首先设计清晰的目录结构,分离路由、处理器、模型与中间件;接着使用Gin初始化HTTP服务并注册路由;定义商品、用户、订单等数据模型,结合GORM自动迁移数据库表;在处理器中实现API逻辑,如查询商品列表;通过JWT中间件实现身份验…

    2025年12月16日
    000
  • Golang如何在Web开发中处理表单错误

    Go语言中处理表单错误需先解析表单数据,使用ParseForm或PostFormValue获取字段值,接着通过手动验证或第三方库检查输入合法性,并用map收集错误信息;若存在错误,则构建包含原始数据和错误提示的结构体,重新渲染页面以保留用户输入,结合模板显示错误消息并用CSS高亮问题字段,避免重定向…

    2025年12月16日
    000
  • Coda 2 中 Go 语言语法高亮的现状与社区参与指南

    本文深入探讨了coda 2文本编辑器中go语言语法高亮功能的当前状态。经多方查证,目前coda 2尚未提供官方或成熟的第三方go语言语法高亮模式。文章将引导用户了解如何通过参与官方功能请求来推动此项功能的开发与实现。 Coda 2 与 Go 语言开发者的挑战 Coda 2 作为一款深受开发者喜爱的文…

    2025年12月16日
    000
  • Revel框架静态文件加载异常排查与解决

    本教程旨在解决revel框架中静态文件(如图片、%ignore_a_1%、js)加载异常的问题,例如显示旧版本或截断文件。核心原因常与`gopath`配置不当、开发环境与`gopath`不一致,或`gopath`内存在重复文件有关。文章将提供详细的诊断步骤,包括检查`gopath`、排查文件副本,并…

    2025年12月16日
    000
  • 解决Revel框架静态文件加载异常:GOPATH与文件路径排查指南

    本文旨在解决revel框架中静态文件加载异常,如文件版本过旧或内容不完整的问题。核心内容包括诊断gopath配置不当、文件路径冲突等常见原因,并提供使用`strace`等工具进行精确排查的方法,确保revel正确地加载和提供静态资源。 在Revel框架开发过程中,开发者有时会遇到静态文件(如CSS、…

    2025年12月16日
    000
  • Golang如何实现错误返回链式调用

    Go中实现错误返回的链式调用需每个方法返回*结构体,error,通过检查err决定是否继续执行。例如ConfigBuilder的SetHost、SetPort方法在出错时设置err并跳过后续操作,最终Build返回首个错误;更灵活的方式是使用函数式选项模式,如RunSteps接受多个返回error的…

    2025年12月16日
    000
  • SOA架构下Go API与Rails应用集成:实现高性能与可管理性的实践指南

    本文深入探讨了从传统rails单体应用向基于api的微服务架构(soa)过渡的策略与实践。重点分析了使用go语言构建api服务与rails作为应用服务器的集成模式,阐明了这种架构的优势,如职责分离、可伸缩性、团队协作效率提升,并解答了关于orm、控制器及功能迁移的常见疑问。通过详细的架构解析和注意事…

    2025年12月16日
    000
  • 如何在Golang中实现条件表达式简写

    Go无三元操作符,但可用IIFE、map索引或泛型函数模拟:1. IIFE用于条件赋值;2. map[bool]T实现状态选择;3. 泛型Ternary函数提升复用性,按场景选最佳方案。 在Golang中,没有像其他语言(如Python的 x if condition else y 或 JavaSc…

    2025年12月16日
    000
  • Golang如何处理微服务间数据序列化

    答案:Go微服务推荐protobuf+gRPC实现高效数据序列化,结合.proto文件生成代码,保证性能与协作效率;简单场景可用JSON,需统一规范避免混合使用。 在微服务架构中,服务间通信的核心是数据序列化。Golang处理微服务间数据序列化通常结合高效的编码格式和清晰的接口定义,以保证性能与可维…

    2025年12月16日
    000
  • Golang如何实现文件缓存与版本控制

    通过哈希校验与内存缓存实现Go文件版本控制,使用SHA256生成文件唯一标识,结合sync.Map缓存内容与元信息,利用ModTime检测变更,并通过Cache-Control设置长效缓存,辅以LRU策略优化内存管理。 在Go语言中实现文件缓存与版本控制,核心是结合本地缓存机制与轻量级版本标识管理。…

    2025年12月16日
    000
  • Go语言中多选项变量声明的实现与类型安全考量

    本文探讨了在go语言中如何实现类似javascript的短路逻辑赋值模式(`var foo = a || b || c;`)。go语言作为一门强类型语言,不支持字符串的“真值”判断,也缺乏三元运算符。因此,需要通过显式的`if/else if/else`结构来安全地选择第一个非空或有效的值,强调go…

    2025年12月16日
    000
  • Go语言中条件式变量赋值的最佳实践

    本文探讨了如何在go语言中实现类似于javascript中利用逻辑或运算符进行条件式变量赋值的模式。go语言由于其强类型特性和缺乏非布尔类型的“真值/假值”概念,以及没有三元运算符,需要采用更显式的方法,即通过`if/else if/else`结构来安全、清晰地完成变量的条件式赋值。 在JavaSc…

    2025年12月16日
    000
  • Go语言中实现多选项变量赋值的惯用方法

    本文探讨如何在go语言中实现类似javascript `var foo = a || b || c;` 的多选项变量赋值逻辑。go语言强调类型安全,不支持字符串等非布尔类型的“真值”判断,也未提供三元运算符。因此,应采用清晰的`if-else if-else`结构进行显式条件判断,确保代码的可读性和…

    2025年12月16日
    000
  • 解决Revel框架静态文件加载异常:GOPATH与文件路径疑难解析

    本教程旨在解决revel框架中静态文件加载异常(如显示旧版本或不完整文件)的问题。核心原因常与`gopath`配置不当或文件路径解析错误有关。文章将提供详细的排查步骤,包括`gopath`一致性检查、文件副本识别以及利用系统工具追踪文件访问路径,并强调在`gopath`内进行revel应用开发的最佳…

    2025年12月16日
    000
  • Golang如何开发投票系统项目

    答案:使用Golang开发投票系统,依托其高并发与高性能优势,结合Gin框架和GORM库,构建包含创建投票、参与投票、防重机制与结果查看的核心功能。通过定义Poll、Option等数据模型,实现RESTful API接口,并利用数据库持久化数据,配合Redis提升防刷票效率,最终通过main.go初…

    2025年12月16日
    000
  • Golang表单多字段验证与数据绑定项目

    首先准备Gin和validator库,定义含binding标签的结构体,如RegisterForm;接着在Gin路由中使用ShouldBind自动绑定并验证表单数据;最后可扩展自定义验证规则,如unique_username,实现安全高效的多字段校验与数据绑定。 在Go语言开发中,处理HTTP请求的…

    2025年12月16日
    000
  • 如何在Golang中处理表单提交与验证

    答案:Golang通过net/http解析表单并结合结构体与validator库实现验证。首先调用r.ParseForm()获取数据,使用FormValue提取字段;接着通过自定义逻辑或第三方库如go-playground/validator进行非空、格式、长度等校验;推荐将表单映射到带标签的结构体…

    2025年12月16日
    000
  • Go语言中从多个选项声明变量的惯用方法

    本文探讨了go语言中如何实现类似javascript的从多个备选值中声明变量的模式。go语言强调类型安全和代码显式性,不支持javascript中字符串的“真值”概念,也没有三元运算符。因此,在go中,应使用清晰的`if-else if-else`结构来检查变量的有效性并进行赋值,以确保代码的健壮性…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信