JavaScript js 左右移动下拉列表选项

最开始想每个方法中用一个循环搞定,后来发现循环删除后。options的索引和集合就发生了变化,删除就不成功。有时候还出现selected为空的现象,2个循环就over了; <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>addMulitOptions.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <script type="text/javascript"> function moveLeft() { var lBox = document.getElementById("leftBox"); var rBox = document.getElementById("rightBox"); var count = 0;; for (var i = 0, len = lBox.length; i < len; i++) { if (lBox[i].selected) { rBox.options.add(new Option(lBox.options[i].text, lBox[i].value)); count++; } } for (var i = 0; i < count; i++) { lBox.remove(lBox.selectedIndex); } } function moveRight() { var lBox = document.getElementById("leftBox"); var rBox = document.getElementById("rightBox"); var count = 0;; for (var i = 0, len = rBox.length; i < len; i++) { if (rBox[i].selected) { lBox.options.add(new Option(rBox.options[i].text, rBox[i].value)); count++; } } for (var i = 0; i < count; i++) { rBox.remove(rBox.selectedIndex); } } </script> </head> <body> <select id="leftBox" multiple="multiple" style="height: 200px; width: 100px;"> <option value="1">a</option> <option value="2">b</option> <option value="3">c</option> <option value="4">d</option> </select> <input type="button" value="&gt;&gt;" οnclick="moveLeft()"/> <input type="button" value="&lt;&lt;" οnclick="moveRight()"/> <select id="rightBox" multiple="multiple" style="height: 200px; width: 100px;"> <option value="11">A</option> <option value="22">B</option> <option value="33">C</option> <option value="44">D</option> </select> </body> </html>

转载于:https://www.cnblogs.com/javaTest/archive/2010/07/20/2589411.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值