数组处理方法总结:改变与不改变原数组

2024-09-06 14:36

本文主要是介绍数组处理方法总结:改变与不改变原数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在写项目处理数组对象的时候,有时候会思考如何快速简洁的实现数据的处理,但在使用的时候,会误解一些不常用的数组方法的意思,导致数据处理结果不对,然后就总结了一份常用的数组处理方法
改变原数组的方法: push()、pop()、shift()、unshift()、splice()、reverse()、sort()、copyWithin()、fill()。
不改变原数组的方法: concat()、slice()、map()、filter()、reduce()、reduceRight()、join()、includes()、indexOf()、find()、findIndex()、every()、some()。

一、改变原数组的方法

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

let arr = [1, 2, 3];
arr.push(4); // [1, 2, 3, 4]

pop(): 移除数组末尾的元素,并返回该元素。

let arr = [1, 2, 3];
arr.pop(); // 返回 3, arr 变成 [1, 2]

shift(): 移除数组的第一个元素,并返回该元素。

let arr = [1, 2, 3];
arr.shift(); // 返回 1, arr 变成 [2, 3]

unshift(): 向数组的开头添加一个或多个元素,并返回新的长度。

let arr = [1, 2, 3];
arr.unshift(0); // 返回 4, arr 变成 [0, 1, 2, 3]

splice(): 从数组中删除、替换或添加元素,直接修改原数组。在这里插入代码片

let arr = [1, 2, 3, 4];
arr.splice(1, 2, 10); // 删除 1 个元素并插入 10, arr 变成 [1, 10, 4]

reverse(): 颠倒数组的顺序。

let arr = [1, 2, 3];
arr.reverse(); // [3, 2, 1]

sort(): 对数组进行排序,默认按字母顺序。可以传入比较函数。

let arr = [3, 1, 2];
arr.sort(); // [1, 2, 3]

copyWithin(): 在当前数组中,复制数组的一部分到另一个位置(会改变原数组)。

let arr = [1, 2, 3, 4, 5];
arr.copyWithin(0, 3); // [4, 5, 3, 4, 5]

fill(): 用指定值填充数组中的部分或所有元素。

let arr = [1, 2, 3];
arr.fill(0); // [0, 0, 0]

二、不改变原数组的方法

concat(): 合并两个或多个数组,返回一个新数组。

let arr1 = [1, 2];
let arr2 = [3, 4];
let newArr = arr1.concat(arr2); // [1, 2, 3, 4]

slice(): 返回数组的一个浅拷贝,指定起始和结束位置(不包括结束位置)。

let arr = [1, 2, 3, 4];
let newArr = arr.slice(1, 3); // [2, 3]

map(): 通过对数组中的每个元素执行一个函数,返回一个新数组。

let arr = [1, 2, 3];
let newArr = arr.map(x => x * 2); // [2, 4, 6]

filter(): 创建一个新数组,包含通过测试的所有元素。

let arr = [1, 2, 3, 4];
let newArr = arr.filter(x => x > 2); // [3, 4]

reduce(): 对数组的每个元素执行累加器函数,最终返回一个值。

let arr = [1, 2, 3];
let sum = arr.reduce((acc, curr) => acc + curr, 0); // 6

reduceRight(): 类似于 reduce(),但从右到左执行。

let arr = [1, 2, 3];
let sum = arr.reduceRight((acc, curr) => acc + curr, 0); // 6

join(): 将数组中的所有元素连接成一个字符串。

let arr = [1, 2, 3];
let str = arr.join("-"); // "1-2-3"

includes(): 检查数组是否包含某个值,返回布尔值。

let arr = [1, 2, 3];
arr.includes(2); // true

indexOf(): 返回数组中首次出现指定值的索引,如果未找到则返回 -1。

let arr = [1, 2, 3];
arr.indexOf(2); // 1

find(): 返回数组中第一个通过测试的元素。

let arr = [1, 2, 3];
let found = arr.find(x => x > 1); // 2

findIndex(): 返回数组中第一个通过测试的元素的索引。

let arr = [1, 2, 3];
let index = arr.findIndex(x => x > 1); // 1

every(): 检查数组中的每个元素是否都通过测试,返回布尔值。

let arr = [1, 2, 3];
arr.every(x => x > 0); // true

some(): 检查数组中是否至少有一个元素通过测试,返回布尔值。

let arr = [1, 2, 3];
arr.some(x => x > 2); // true

这篇关于数组处理方法总结:改变与不改变原数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142284

相关文章

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA