简单回顾下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更安全‌
相关推荐
小陈工33 分钟前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全
IT_陈寒1 小时前
Vue的这个响应式问题,坑了我整整两小时
前端·人工智能·后端
HIT_Weston1 小时前
41、【Agent】【OpenCode】本地代理分析(五)
javascript·人工智能·opencode
C澒1 小时前
AI 生码:A 类生码方案架构升级
前端·ai编程
前端Hardy2 小时前
前端必看!LocalStorage这么用,再也不踩坑(多框架通用,直接复制)
前端·javascript·面试
前端Hardy2 小时前
前端必看!前端路由守卫这么写,再也不担心权限混乱(Vue/React通用)
前端·javascript·面试
Lee川2 小时前
从零构建现代化登录界面:React + Tailwind CSS 前端工程实践
前端·react.js
Awu12272 小时前
⚡精通 Claude 第 1 课:掌握 Slash Commands
前端·人工智能·ai编程
竹林8182 小时前
从ethers.js迁移到Viem:我在重构DeFi前端时踩过的那些坑
前端·javascript
码云之上2 小时前
上下文工程实战:解决多轮对话中的"上下文腐烂"问题
前端·node.js·agent