javascript在数组的循环中删除元素

在开发JavaScript应用的过程当中,常常会遇到在循环中移除指定元素的需求。数组

按照常规的思路,就是对数组进行一个for循环,而后在循环里面进行if判断,在判断中删除掉指定元素便可。spa

可是实际状况每每不会像预想的那样顺利运行。设计

出现的问题场景还原code

(function () { var arr = [1, 2, 2, 3, 4, 5]; for (var i = 0; i < arr.length; i++){ // 打印数组中的状况,便于跟踪数组中数据的变化
        console.log(i + ' = ' + arr[i]); // 删除掉全部为2的元素
        if(arr[i] === 2) { arr.splice(i, 1); } } console.log(arr); })();

从最终的结果能够看到,这段代码实际上只删除掉了匹配的其中一个元素,而另外一个匹配条件的元素还存在,并不符合程序设计的初衷。blog

而从打印出来的运行过程不难发现,产生这个结果的缘由是由于,当删除掉了一个元素后,数组中元素的索引(下标)发生了实时变化,形成了程序的异常。索引

解决问题的方法ip

找到了出现问题的缘由,就不难解决问题了。开发

方法1:实时调整数组中元素的下标对应关系。io

(function () { var arr = [1, 2, 2, 3, 4, 5]; for (var i = 0; i < arr.length; i++){ // 打印数组中的状况,便于跟踪数组中数据的变化
        console.log(i + ' = ' + arr[i]); // 删除掉全部为2的元素
        if(arr[i] === 2) { arr.splice(i--, 1); } } console.log(arr); })();

出现问题的缘由,是由于移除掉中间的一个元素以后,该元素后面的元素的索引(下标)都往前加1了,那么咱们能够在删除元素后手动将循环中的下标重置为如今对应的下标便可(i--)。console

方法2:从后往前遍历数组元素。

(function () { var arr = [1, 2, 2, 3, 4, 5]; for (var i = arr.length - 1; i >= 0; i--) { // 打印数组中的状况,便于跟踪数组中数据的变化
        console.log(i + ' = ' + arr[i]); // 删除掉全部为2的元素
        if(arr[i] === 2) { arr.splice(i, 1); } } console.log(arr); })();

出现问题的缘由,是由于移除掉中间的一个元素以后,该元素后面的元素的索引(下标)都往前加1了,那么只要是从后往前循环,就能够不用管后面元素的索引(下标)了。

方法3:使用while循环代替for循环(仍是从后往前循环)。

(function () { var arr = [1, 2, 2, 3, 4, 5]; var i = arr.length; while(i--) { console.log(i + ' = ' + arr[i]); if(arr[i] === 2) { arr.splice(i, 1); } } console.log(arr); })();

同上面从后往前循环的原理一致,只是将for循环使用了while循环代替。

 

"明天的今天是昨天,昨天又是新的一天。"

相关文章
相关标签/搜索