用心感受数组中强大的splice方法

最近在梳理JavaScript数组这一块知识点时,想到了splice方法。于是在睡觉之前脑海中一遍遍走过,其实在我的日常工作中,感觉splice是使用次数远远不及forEach、filter这种。但我知道splice是数组中一个很重要又很强大的方法,于是今天早起,就想找个时间和大家好好说道说道。

一、概念

首先 splice数组 的一个方法注意它的使用会改变原数组的值,根据我们工作中的实际情况,它可以接收三个参数

splice的实际作用就是对原数组进行增加删除修改

二、参数使用

2.1 一个参数

  1. 一个参数 的情况,多用来进行截取(相当于删除元素组中的一些项),标识从n开始一直到数组末尾,这种情况的返回值是一个我们截取值的数组

    js 复制代码
    const arr = [1, 2, 3, 4, 5];
    console.log(arr); // [1, 2, 3, 4, 5];
    
    const newArr = arr.splice(2);
    console.log(arr); // [1, 2];
    console.log(newArr); // [3, 4, 5];
  2. 这里可能有想伙伴要说我想截取某一部分怎么办,那我们就要使用slice方法啦。

    js 复制代码
    const arr = [1, 2, 3, 4, 5];
    console.log(arr); // [1, 2, 3, 4, 5];
    
    const newArr = arr.slice(2, 4);
    console.log(arr); // [1, 2, 3, 4, 5];
    console.log(newArr); // [3, 4];

    注意 :slice改变原数组,再一点就是这个取件是前闭后开的。

  3. splice也可以接收一个负数

    当我们传递的参数为-1时,此时指向的是数组的最后一项,这里我想获取数组的最后三项也可以这样写。

    js 复制代码
    const arr = [1, 2, 3, 4, 5];
    console.log(arr); // [1, 2, 3, 4, 5];
    
    const newArr = arr.slice(-3);
    console.log(arr); // [1, 2, 3, 4, 5];
    console.log(newArr); // [3, 4, 5];

2.2 两个参数

  1. 两个参数是删除的意思,标识从下标n开始删除m个项,返回值是一个删除的数组。比如我们删除下标2的值。

    js 复制代码
    const arr = [1, 2, 3, 4, 5];
    console.log(arr); // [1, 2, 3, 4, 5];
    
    const newArr = arr.splice(2, 1);
    console.log(arr); // [1, 2, 4, 5];
    console.log(newArr); // [3];
  2. 两个参数也是支持负数

    js 复制代码
    const arr = [1, 2, 3, 4, 5];
    console.log(arr); // [1, 2, 3, 4, 5];
    
    const newArr = arr.splice(-1, 1);
    console.log(arr); // [1, 2, 3, 4];
    console.log(newArr); // [5];

3.3 三个参数(大于等于三个参数)

splice(start , deleteCount, item1, item2, ... )

我们先来说两种情况,分别解释一下每个参数的作用。

  • start大于0时

    • deleteCount0 时,不删除只添加。在start位置前添加item1, ..., itemN的数
    • deleteCount > 0 删除且添加,删除从start位置开始的数,deleteCount为删除的个数,并且在start位置前添加item1, ..., itemN的数。
  • start小于0时,最后一个数为 -1

    • deleteCount0 时 不删除只添加,在-start位置前添加item1, ..., itemN的数

    • deleteCount > 0 删除且添加,删除从-start位置开始的数,deleteCount为删除的个数,并且在-start位置前添加item1, ..., itemN的数

      js 复制代码
      // 新增
      const arr = [1, 2, 3, 4, 5];
      console.log(arr); // [1, 2, 3, 4, 5];
      
      const newArr = arr.splice(2, 0, 6);
      console.log(arr); // [1, 2, 6, 3, 4, 5];
      console.log(newArr); // [];
      
      // 替换
      const arr = [1, 2, 3, 4, 5];
      console.log(arr); // [1, 2, 3, 4, 5];
      
      const newArr = arr.splice(2, 1, 6);
      console.log(arr); // [1, 2, 6, 4, 5];
      console.log(newArr); // [3];

三、总结

今天是整理了一下数组中splice中的用法,一般我们就是使用其中的删除替换。目的是让大家对splice加深印象,在面试中可能会被提问到。

相关推荐
云水一下3 小时前
从零开始!VMware安装Fedora Workstation 44桌面系统完整教程
前端
小码哥_常4 小时前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd4 小时前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码15 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen5 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦6 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen6 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
不会敲代码16 小时前
从零搭建 AI 日记助手:用 Milvus 向量数据库实现语义搜索
javascript·openai
千寻girling6 小时前
《 Git 详细教程 》
前端·后端·面试
threelab7 小时前
Three.js UV 图像变换效果 | 三维可视化 / AI 提示词
javascript·人工智能·uv