我想拼接我的数组,所以我创建了这段代码:
System.log(finalcluster.length);
for (i=0; i <= finalcluster.length; i++){
if (finalcluster[i] != undefined ){
System.log(finalcluster[i][0]);
var remove = finalcluster.indexOf("dump");
if (finalcluster[i][0] == "dump")
{
System.log("couse dump");
finalcluster.splice(remove,1);
}
else {
System.log("No Problem");
}
}
}
在这段代码中有两个删除函数,我知道是因为我尝试了一个整数 i 的索引。
当我执行这段代码时,只删除了两个转储,我认为在我的正确结果之前和之后的两个转储,还有另一个“转储”数组。为什么split不能移动它,因为它可以从关键字之前开始拼接数组。
数组:
[Name][Number]
[dump][0]
[dump][0]
[KEYWORD][KEYNUMBER]
[dump][0]
[dump][0]
这就是数组模型。
最佳答案
您的代码存在一个问题,即您在更改(递减)数组长度时使用 finalcluster.length
按升序迭代 finalcluster
。因此,每次满足删除条件时,循环运行的次数都会减少 1,这使得数组的尾部无法访问。示例:
// seems like this would empty out the array
let arr = [1, 2, 3, 4]
for (let i = 0; i < arr.length; i++) {
arr.splice(i, 1)
}
console.log(arr); // [2, 4]
您可以通过以相反顺序迭代 finalcluster
来避免此问题
let arr = [1, 2, 3, 4]
for (let i = arr.length - 1; i >= 0; i--) {
arr.splice(i, 1)
}
console.log(arr)
关于javascript - JS 拼接一个数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46121961/