简单回顾下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更安全‌
相关推荐
Yvonne爱编码33 分钟前
CSS- 1.1 css选择器
前端·css·状态模式·html5·hbuilder
SHIPKING39334 分钟前
【HTML】个人博客页面
javascript·css·html
山河故人16344 分钟前
uniapp使用npm下载
前端·npm·uni-app
-曾牛1 小时前
基于微信小程序的在线聊天功能实现:WebSocket通信实战
前端·后端·websocket·网络协议·微信小程序·小程序·notepad++
一口一个橘子2 小时前
[ctfshow web入门] web72
前端·web安全·网络安全
Web极客码2 小时前
如何使用WordPress SEO检查器进行实时内容分析
前端·seo·wordpress
Stella25212 小时前
【Vue】CSS3实现关键帧动画
前端·vue.js·css3
junjun.chen06062 小时前
【在qiankun模式下el-dropdown点击,浏览器报Failed to execute ‘getComputedStyle‘ on ‘Window‘: parameter 1 is not o
前端·javascript·前端框架
課代表2 小时前
AcroForm JavaScript Promise 对象应用示例: 异步加载PDF文件
开发语言·javascript·pdf·promise·对象
Yvonne爱编码2 小时前
HTML-3.3 表格布局(学校官网简易布局实例)
前端·html·github·html5·hbuilder