如何解决数组的splice方法在for循环中出现的问题?

2023-11-10 10:40

本文主要是介绍如何解决数组的splice方法在for循环中出现的问题?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

产生问题的场景:

在这里插入图片描述
在这里插入图片描述
在做下拉框选中项左右移动的练习时,出现了上图所示的问题,当我选择的是“法国”、“美国”、“英国”,点击‘选中项右移’,会出现undefined选项,并且"美国"选项没有移动到右边的下拉框中。代码如下

<script type="text/javascript">var unSelArr=['中国','美国','俄罗斯','英国','法国'];var selArr=[]var ulSel=document.getElementById('ulSel')var sel=document.getElementById('sel')ulSel.innerHTML=unSelArr.sort().map(val=>`<option>${val}</option>`).join("")`在这里插入代码片`//选中右移var btnRight=document.getElementById('btnRight')btnRight.onclick=function(){for(var i=0;i<ulSel.length;i++){if(ulSel.options[i].selected==true){selArr.push(unSelArr.splice(i,1)[0])selArr.sort()}}ulSel.innerHTML=unSelArr.sort().map(elem=>"<option>"+elem+"</option>").join("");sel.innerHTML=selArr.sort().map(elem=>"<option>"+elem+"</option>").join("");}
</script>

我的思路是:
遍历左边下拉框的选项,当选项被选中,就删除左边下拉框的选项对应的数组中的数据,并将删除的数据添加到右边下拉框选项对应的数组中,最后渲染数组中的数据到页面中。

由于代码没有报错,所以我想着是不是逻辑上出现问题导致出现undefined,在多次的调测下,将问题定位在splice方法上,并且在控制台进行测试
在这里插入图片描述
果然,问题是splice方法,因为splice会删除原数组中的值,这个值被删除以后,后面值的下标索引就向前进了一位,那么后面值的下标索引就变成删除值的下标索引,而对于for循环来说,这个下标索引已经循环过了,所以后面的值会跳出循环。

最后想到了一种简便的方法处理这个问题,就是直接从后向前遍历,那么这个问题就可以避免,代码如下:

<script type="text/javascript">var unSelArr=['中国','美国','俄罗斯','英国','法国'];var selArr=[]var ulSel=document.getElementById('ulSel')var sel=document.getElementById('sel')ulSel.innerHTML=unSelArr.sort().map(val=>`<option>${val}</option>`).join("")`在这里插入代码片`//选中右移var btnRight=document.getElementById('btnRight')btnRight.onclick=function(){for(var i=ulSel.length-1;i>=0;i--){if(ulSel.options[i].selected==true){selArr.push(unSelArr.splice(i,1)[0])selArr.sort()}}ulSel.innerHTML=unSelArr.sort().map(elem=>"<option>"+elem+"</option>").join("");sel.innerHTML=selArr.sort().map(elem=>"<option>"+elem+"</option>").join("");}
</script>![在这里插入图片描述](https://img-blog.csdnimg.cn/1d00c2f4ad1d434ea343f4ea8b569b94.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/fe939ff4e4e84efea85260cca9e6159d.png)

这篇关于如何解决数组的splice方法在for循环中出现的问题?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/382128

相关文章

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。