我有两个数组,available_items
并且requested_items
. 我想从中requested_items
删除available_items
. UsingforEach
显然不会给出预期的结果,因为即使删除了一个元素并且下一个元素将具有旧索引,内部索引也会增加。
这是一个测试用例(也在这个 jsbin中):
var available_items = [2, 5, 9, 36, 48, 23];
var requested_items = [5, 12, 49, 30, 90, 17];
requested_items.forEach(function(v, i, a) {
if(available_items.indexOf(v) == -1) {
console.log("will remove " + i + ' ' + v);
a.splice(i, 1);
} else console.log("will keep " + i + ' ' + v);
});
console.log('Resulting request array is ' + requested_items.toString());
结果是:
"will keep 0 5"
"will remove 1 12"
"will remove 2 30"
"will remove 3 17"
"Resulting request array is 5,49,90"
这将重复数万次,因此,如果使用库(例如下划线)对性能产生不利影响,我希望避免这种情况。
所以,我的问题是,纠正这个问题的最便宜的方法是什么?