javascript – 如何判断未定义的数组元素和空插槽?

假设我是一个用户脚本开发人员,我无法控制页内 JavaScript.该页面创建具有随机长度的数组,用随机值填充(包括伪造的数组,如未定义的).不是每个元素都必须分配一个值,所以可能有空插槽.

一个简化的例子(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显示未定义和空插槽不同,而对于javascript,它们似乎是相同的.

现在假设我要清理这样一个数组,删除所有的空插槽,但保留未定义的元素.我怎么做?

解决方法

您可以使用 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( function ( _,i ) { return i in arr } );

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...