前端实习生的这个 bug 被用做了一道基础面试题

前言

测试发现了一个问题,简单描述问题就是通过函数删除一个数组中多个元素,传入的参数是一个数组索引。

然后发现实际效果有时删除的不是想要的内容。

欢迎关注公众号《前端界》,文章会同步更新,也可快速加入前端交流群!

具体 Bug 代码实现:

js 复制代码
const arr = [1,2,3,4,5,6,7];
const removeData = (rowIndexs:Array<number>)=>{
    if(Array.isArray(rowIndexs)){
        rowIndex.forEach((index)=>{
            arr.splice(index,1)
        })
    }
}
removeData([1,4]); 
console.log(arr); // 输出结果 [1,3,4,5,7]
// 期望输出结果 [1,3,4,6,7]

上面代码出现问题的原因是 splice 会改变原始数组的,然后导致索引偏移,不知道有没有同学出过类似问题。

因为这个 bug 我发现有些同学基础该是比较差,导致一些不必要的问题,于是把它变成了一道基础面试题,注意考基础,同时删除数组中的多个元素利用索引数组有多少种方式,把可以想到的方法都写一下哦(其实不是为了难为人,知识想考察一下面试者javaScript的基础编写能力) 接下来介绍这几种方法,欢迎补充

方法一:先倒序后删除

这种方式将参数索引数组按照从大到小排序,避免了删除元素导致的索引偏移

js 复制代码
const arr = [1,2,3,4,5,6];
const removeMultipleElement = (rowIndexs)=>{
    // 先倒序
    if(Array.isArray(rowIndexs)){
        rowIndexs = rowIndexs.sort((a,b)=>b-a);
        rowIndex.forEach((rowIndex)=>{
            arr.splice(rowIndex,1);
        })
    }
}
removeMultipleElement([1,4]);
console.log(arr);

方法二:使用filter生成新数组

使用 filter 生成新数组,并且结合 includes 。(注意 filter 过滤的内容是浅拷贝过程)

js 复制代码
const arr = [1,2,3,4,5,6];
cons removeMultipleElement = (rowIndexs)=>{
    if(Array.isArray(rowIndexs)){
        arr =  arr.filter((_,index)=>!rowIndex.includes(index))
    }
}
removeMultipleElement([1,4]);
console.log(arr);

方法三:使用reduce生成新数组

使用 reduceincludes 函数,也会生成新数组

js 复制代码
const arr = [1,2,3,4,5,6];
cons removeMultipleElement = (rowIndexs)=>{
    if(Array.isArray(rowIndexs)){
        arr = arr.reduce((prev,current,currentIndex)=>{
            if(!rowIndexs.includes(rowIndex)){
                prev.push(current)
            }
            return prev
        },[])
    }
}
removeMultipleElement([1,4]);
console.log(arr);

方法四:生成新数组,判断用Set.has 替换 includes

仍然会生成新数组,只是 includes 判断使用 set.has 替换,set.has 判断会比 includes 的性能好一些,但是也要考虑数组数据量的大小,如果只是几个值,可以不考虑

js 复制代码
const arr = [1,2,3,4,5,6];
let newArr = [];
cons removeMultipleElement = (rowIndexs)=>{
  const rowIndexsSet = new Set(rowIndex);
  arr.forEach((item,index)=>{
      if(!rowIndexSet.has(index)){
          newArr.push(item)
      }
  })
}
removeMultipleElement([1,4]);
console.log(arr);

方法五:标记删除法加 filter

创建一个与原始数组相同长度的布尔数组 markedForDeletion,用于标记需要删除的元素。然后,我们遍历索引数组,将对应的标记设置为 true。最后,我们使用 filter 方法创建一个新数组,只保留未被标记为删除的元素。

js 复制代码
const arr = [1,2,3,4,5,6];
cons removeMultipleElement = (rowIndexs)=>{
   const markedForDeletion = new Array(arr.length).fill(false);
   for(const index of rowIndexs){
       markedForDeletion[index] = true;
   }
   arr = arr.filter((_,index)=>!markedForDeletion[index])
}
removeMultipleElement([1,4]);
console.log(arr);

总结

目前针对这道题函数删除一个数组中多个元素,传入的参数是一个数组索引总结了几种解法,也避免了最初的 bug,欢迎大家评论提供更多的方法。

欢迎关注公众号《前端界》,文章会同步更新,也可快速加入前端交流群!

如果有收获欢迎点赞,转发,收藏支持下

相关推荐
A_nanda29 分钟前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06261 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~1 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle1 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界2 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser2 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20353 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜3 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
天天鸭4 小时前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
发现一只大呆瓜4 小时前
前端模块化:CommonJS、AMD、ES Module三大规范全解析
前端·面试·vite