javascript - 为什么我的数组中有空项目,我该如何摆脱它们?

标签 javascript arrays function for-loop

这个问题在这里已经有了答案:





How can I remove a specific item from an array?

(136 个回答)


4年前关闭。




我正在使用 Visual Studio 代码。我正在尝试使用 JavaScript 返回一个只有奇数的数组。这是代码:

function oddCouple(arr) {
  for (let i = 0; i < arr.length; i++) {
    if (arr[i] % 2 == 0) {
      delete arr[i];
    }
  }
  return arr;
}

console.log(oddCouple([2, 6, 7, 0, 1, 3, 7, 5]));


这就是我得到的。我不想要空的项目,只是奇数。
[ <2 empty items>, 7, <1 empty item>, 1, 3, 7, 5 ]

最佳答案

您需要使用 splice()而不是删除,因为 delete不会改变数组的长度。但要小心使用 splice()for循环,因为您在循环遍历数组时会更改数组,但效果不佳。

另一种方法是向后循环:

function oddCouple(arr) {
  for (let i = arr.length - 1; i >= 0; i--) {
    if (arr[i] % 2 == 0) {
      arr.splice(i, 1);
    }
  }
  return arr;
}

console.log(oddCouple([2, 6, 7, 0, 1, 3, 7, 5]));


当然,更好的选择是使用 filter() ,但请注意,这不会更改原始数组。

function oddCouple(arr) {
  return arr.filter(i => i % 2)  
}

console.log(oddCouple([2, 6, 7, 0, 1, 3, 7, 5]));

关于javascript - 为什么我的数组中有空项目,我该如何摆脱它们?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51688366/

相关文章:

javascript - 使用 jQuery 或 JavaScript 使用另一个数组过滤数组

c# - 我的 Windows 服务实例需要一个贡献函数

javascript - 如何在 React 中使用 API 进行异步调用?

javascript - 如何使用 AngularJS 创建 html 页面模板并将 Controller 动态绑定(bind)到它?

javascript - 在使用 Protractor 进行 e2e 测试时记录 xhr 请求

php - "Notice: Undefined variable"、 "Notice: Undefined index"、 "Warning: Undefined array key"和 "Notice: Undefined offset"使用 PHP

javascript - Underscore.js 从数组中的值中获取键

javascript - JavaScript 中的参数数组 (ES5)

Javascript 函数立即停止

javascript - Jquery 无冲突 - Onclick 函数 - 多框架