HTML+JS实现左边select移动到右边select

如图所示:左右两个select标签,左边有10个option,

要求实现双击左侧选项即可移动到右侧,选择选项后点击“批量右移”可以移动到右侧,点击“全部右移”则全部一次性右移到右侧。

实现代码如下:

<div id="" style="position: absolute;left: 10px;top: 20px;">
	<select style="width: 70px;" id="leftID" size="10" multiple="multiple" >
		<option value="">A</option>
		<option value="">B</option>
		<option value="">C</option>
		<option value="">D</option>
		<option value="">E</option>
		<option value="">F</option>
		<option value="">G</option>
		<option value="">H</option>
		<option value="">I</option>
		<option value="">J</option>
	</select>
</div>
<div id="" style="position: absolute;left: 100px;top: 60px;">
	<input type="button" name="rightMoveID" id="rightMoveID" value="批量右移" />		
</div>
<div id="" style="position: absolute;left: 100px;top: 90px;">
	<input type="button" name="rightMoveAllID" id="rightMoveAllID" value="全部右移" />		
</div>
<div id="" style="position: absolute;left: 200px;top: 20px;">
	<select style="width: 70px;" id="rightID" size="10" multiple="multiple"></select>		
</div>
<script type="text/javascript">
	document.getElementById("leftID").ondblclick = function() {
		var optionElement = this[this.selectedIndex];
		document.getElementById("rightID").appendChild(optionElement) ;
	}
	document.getElementById("rightMoveAllID").onclick = function() {
		var leftSelectElement = document.getElementById("leftID") ;
		var size = leftSelectElement.length;
		for(var i=0;i<size;i++) {
			var optionElement = leftSelectElement.options[0] ;
			document.getElementById("rightID").appendChild(optionElement) ;
		}
	}
	document.getElementById("rightMoveID").onclick = function(){
		var selectElement = document.getElementById("leftID") ;
		var optionElements = selectElement.getElementsByTagName("option") ;
		for(var i=0;i<optionElements.length;i++) {
			if(optionElements[i].selected == true) {
				document.getElementById("rightID").appendChild(optionElements[i]) ;
				i=i-1;//解释为什么要减一,
				//每次移动那个option后,那个option就会被删除,
				//所以需要把index移动到被删除的那个option的前一个index那里才可以。
			}
		}
	}
</script>

代码拙劣啊哈哈。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值