javascript - 如何区分未定义的数组元素和空槽?

标签 javascript arrays undefined

假设我是一名用户脚本开发人员,我无法控制页面上的 javascript。该页面创建具有随机长度的数组,并用随机值填充它们(包括虚假值,例如 undefined)。并非每个元素都必须分配一个值,因此可能会有空槽。

一个简化的例子(Firefox 控制台):

var arr = new Array(3);
arr[0] = null;
arr[1] = undefined;
console.log(arr);               \\ Array [ null, undefined, <1 empty slot> ]
console.log(arr[1]);            \\ undefined
console.log(arr[2]);            \\ undefined
console.log(arr[1] === arr[2]); \\ true
console.log(typeof arr[1]);     \\ undefined
console.log(typeof arr[2]);     \\ undefined

正如我们所见,Firefox 以不同方式显示 undefined 和空插槽,而对于 javascript,它们似乎是相同的。

现在假设我想清理这样一个数组,删除所有空槽,但保留 undefined 元素不变。我该怎么做?

最佳答案

您可以使用 in运算符检查数组是否有键。它将为空插槽返回 false,但对于具有值的插槽返回 true,包括值 undefined:

var arr = new Array(3);
arr[0] = null;
arr[1] = undefined;

1 in arr; // true
2 in arr; // false

请注意,您无法使用它来区分空槽和超出数组末尾的槽,但如果您知道数组的长度,那么您已经知道 3 不是它的一部分,所以你不需要在 arr 中测试 3

您还可以像这样过滤掉空槽:

arr = arr.filter( ( _, i ) => i in arr );

关于javascript - 如何区分未定义的数组元素和空槽?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40752434/

相关文章:

ios - Swift:正确初始化和访问数组中的类

javascript - 查看数组的子数组是否存在

JavaScript 二维数组导致 "Cannot read property ' undefined' of undefined"

javascript - react : How to shift focus using arrow keys?( TreeView )

javascript - 根据下拉菜单更改注册表单?

javascript - 如何将函数数组应用于 Javascript 中相应参数的数组?

c++ - 错误 C2027 : use of undefined type 'edge'

c++ - 从另一个文件调用 C++ 函数时出现 "Undefined Symbols"

javascript - 将现有的backboneJS应用程序转换为angularJS应用程序的最佳方法是什么

javascript - 邮政编码和城市列表,excel 方舟还是数据库?