简单回顾下es6增数组方法

新增方法均返回新数组,避免直接修改原数组,提升代码可维护性‌。

  1. ‌**Array.prototype.toReversed()** ‌

    作用:创建原数组倒序副本,原数组不变 示例:

    ini 复制代码
    const arr = [1, 7, 3];
    const reversed = arr.toReversed(); // [3, 7, 1]
    console.log(arr); // 原数组保持 [1, 7, 3]

‌**reverse() 修改原数组**‌

ini 复制代码
const originalArr = [1, 2, 3, 4];
const reversedArr = originalArr.reverse();

console.log(originalArr);   // 输出: [4, 3, 2, 1](原数组被修改)
console.log(reversedArr);   // 输出: [4, 3, 2, 1](与原数组是同一个引用)
  1. ‌**Array.prototype.toSorted()** ‌

    作用:创建排序后的副本

    示例:

    css 复制代码
    const arr = [5, 1, 4];
    const sorted = arr.toSorted((a, b) => a - b); // [1, 4, 5]
  2. ‌**Array.prototype.toSpliced()** ‌

    作用:安全执行删除/替换操作,不修改原数组

    示例:

    ini 复制代码
    const arr = ['a', 'b', 'c'];
    const spliced = arr.toSpliced(1, 1, 'x'); // ['a', 'x', 'c']

ini 复制代码
const arr2 = [1, 2, 3, 4];
const newArr2 = arr2.toSpliced(1, 2, 'a'); 
console.log(arr2);        // [1, 2, 3, 4](原数组未变)‌
console.log(newArr2);     // [1, 'a', 4](生成新数组)

- ‌**splice() 修改原数组**‌

ini 复制代码
```
const arr1 = [1, 2, 3, 4];
const deleted1 = arr1.splice(1, 2, 'a'); 
console.log(arr1);        // [1, 'a', 4](原数组被修改)‌
console.log(deleted1);    // [2, 3](返回被删除元素)
```

二、‌元素修改方法

  1. ‌**Array.prototype.with(index, value)** ‌

    作用:替换指定索引元素,返回新数组

    示例:

    ini 复制代码
    const arr = [10, 20, 30];
    const newArr = arr.with(1, 99); // [10, 99, 30]‌

三、‌应用场景对比

方法 典型场景 对比传统方法
toReversed 需要保留原数组的倒序操作 替代reverse()的破坏性操作‌
with 不可变数据更新(如Redux) arr[index]=val更安全‌
相关推荐
QQ1__81151751523 分钟前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态25 分钟前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子26 分钟前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室28 分钟前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI28 分钟前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing28 分钟前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者28 分钟前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册28 分钟前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李31 分钟前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢33 分钟前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web