基于javascript实现单选及多选的向右和向左移动实例


Posted in Javascript onJuly 25, 2015

本文实例讲述了基于javascript实现单选及多选的向右和向左移动实例。分享给大家供大家参考。具体实现方法如下:

方法 一:

<body>
<h1>实现单选及多选的向右和向左移动</h1>
<div id="lst">
  <span>
  <select id="lselect" size="10" multiple="multiple" style="width: 100px; background-color:blue;">
  <option>选项1</option>
  <option>选项2</option>
  <option>选项3</option>
  <option>选项4</option>
  <option>选项5</option>
  <option>选项6</option>
  <option>选项7</option>
  <option>选项8</option>
  <option>选项9</option>
  <option>选项10</option>
  </select>
  <span style="width: 200px;height: 100px;">
  <input type="button" value="单个向右移动" onclick="oneRMove()" />
  <input type="button" value="多个向右移动" onclick="moveRMove()" />
  <input type="button" value="单个向左移动" onclick="oneLMove()" />
  <input type="button" value="多个向左移动" onclick="moveLMove()" />
  </span>
  <span>
  <select id="rselect" size="10" style="width: 100px;background-color: yellow;" multiple="multiple">
  </select>
  </span>
  </span>
</div> 
</body>
<script type="text/javascript">
window.onload = function(){}
//获取select对象
var lselect=document.getElementById("lselect");
var rselect=document.getElementById("rselect");
//获取lselect和roptions对象中的所有option
var loptions=lselect.options;
var roptions=rselect.options;
function oneRMove(){
for(var i=0;i<loptions.length;i++){
var op=loptions[i];
if(op.selected){
rselect.appendChild(op);
break;
}
}
}
function moveRMove(){
for(var i=0;i<loptions.length;i++){
var op=loptions[i];
if(op.selected){
rselect.appendChild(op);
i--;
}
}
}
function oneLMove(){
for(var i=0;i<roptions.length;i++){
var op=roptions[i];
if(op.selected){
lselect.appendChild(op);
break;
}
}
}
function moveLMove(){
for(var i=0;i<roptions.length;i++){
var op=roptions[i];
if(op.selected){
lselect.appendChild(op);
i--;
}
}
}
</script>

方法 二:

<script type="text/javascript">
sortitems = 1;
function move(fbox,tbox) {
for(var i=0; i<fbox.options.length; i++) {
if(fbox.options[i].selected && fbox.options[i].value != "") {
var no = new Option();
no.value = fbox.options[i].value;
no.text = fbox.options[i].text;
tbox.options[tbox.options.length] = no;
fbox.options[i].value = "";
fbox.options[i].text = "";
  }
}
BumpUp(fbox);
if (sortitems) SortD(tbox);
}
function BumpUp(box) {
for(var i=0; i<box.options.length; i++) {
if(box.options[i].value == "") {
for(var j=i; j<box.options.length-1; j++) {
box.options[j].value = box.options[j+1].value;
box.options[j].text = box.options[j+1].text;
}
var ln = i;break;
  }
}
if(ln < box.options.length) {
box.options.length -= 1;
BumpUp(box);
  }
}
function SortD(box) {
var temp_opts = new Array();         
var temp = new Object();           
for(var i=0; i<box.options.length; i++) { 
temp_opts[i] = box.options[i];
}
for(var x=0; x<temp_opts.length-1; x++) {
for(var y=(x+1); y<temp_opts.length; y++) {
if(temp_opts[x].text > temp_opts[y].text) {
temp = temp_opts[x].text;
temp_opts[x].text = temp_opts[y].text;
temp_opts[y].text = temp;
temp = temp_opts[x].value;
temp_opts[x].value = temp_opts[y].value;
temp_opts[y].value = temp;
   }
  }
}
for(var i=0; i<box.options.length; i++) {
box.options[i].value = temp_opts[i].value;
box.options[i].text = temp_opts[i].text;
  }
}
</script>
</head>
<body>
<form ACTION="" METHOD="POST">
<table border="0">
<tr>
<td><select multiple size="5" name="list1">
<option value="l1">A</option>
<option value="l2">B </option>
<option value="l3">C</option>
<option value="l4">D</option>
</select></td>
<td>
<input type="button" value="向右" onclick="move(this.form.list1,this.form.list2)" name="B1"><br>
<input type="button" value="向左" onclick="move(this.form.list2,this.form.list1)" name="B2">
</td>
<td><select multiple size="5" name="list2">
<option value="r1">E</option>
<option value="r2">F </option>
<option value="r3">G</option>
<option value="r4">H</option>
</select></td>
</tr>
</table>
</form>
</body>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
非常强大的 jQuery.AsyncBox 弹出对话框插件
Aug 29 Javascript
IE6已终止操作问题的2种情况及解决
Apr 23 Javascript
javascript框架设计之浏览器的嗅探和特征侦测
Jun 23 Javascript
使用JQuery实现智能表单验证功能
Mar 08 Javascript
jQuery控制div实现随滚动条滚动效果
Jun 07 Javascript
利用css+原生js制作简单的钟表
Apr 07 Javascript
JavaScript提高加载和执行效率的方法
Feb 03 Javascript
vue中v-model动态生成的实例详解
Oct 27 Javascript
JavaScript中Object基础内部方法图
Feb 05 Javascript
p5.js入门教程之平滑过渡(Easing)
Mar 16 Javascript
vue自定义switch开关组件,实现样式可自行更改
Nov 01 Javascript
vue 监听 Treeselect 选择项的改变操作
Aug 31 Javascript
javascript实现信息增删改查的方法
Jul 25 #Javascript
jQuery菜单插件用法实例
Jul 25 #Javascript
javascript单例模式的简单实现方法
Jul 25 #Javascript
JavaScript类继承及实例化的方法
Jul 25 #Javascript
JavaScript对Cookie进行读写操作实例
Jul 25 #Javascript
javascript去掉代码里面的注释
Jul 24 #Javascript
Jquery简单分页实现方法
Jul 24 #Javascript
You might like
在PHP中执行系统外部命令
2006/10/09 PHP
php利用cookie实现访问次数统计代码
2011/05/19 PHP
php使用fgetcsv读取csv文件出现乱码的解决方法
2014/11/08 PHP
Zend Framework教程之视图组件Zend_View用法详解
2016/03/05 PHP
Laravel框架实现发送短信验证功能代码
2016/06/06 PHP
PHP数据的提交与过滤基本操作实例详解
2016/11/11 PHP
JavaScript 创建对象
2009/07/17 Javascript
前后台交互过程中json格式如何解析以及如何生成
2012/12/26 Javascript
JS页面延迟执行一些方法(整理)
2013/11/11 Javascript
JS判断对象是否存在的10种方法总结
2013/12/23 Javascript
jQuery统计上传文件大小的方法
2015/01/24 Javascript
浅析node连接数据库(express+mysql)
2015/11/30 Javascript
js实现精确到毫秒的倒计时效果
2016/08/05 Javascript
jQuery 实现ajax传入参数含有特殊字符的方法总结
2016/10/17 Javascript
基于touch.js手势库+zepto.js插件开发图片查看器(滑动、缩放、双击缩放)
2016/11/17 Javascript
js css自定义分页效果
2017/02/24 Javascript
javascript回调函数详解
2018/02/06 Javascript
解决vue router组件状态刷新消失的问题
2018/08/01 Javascript
js实现页面图片消除效果
2020/03/24 Javascript
JS实现页面侧边栏效果探究
2021/01/08 Javascript
python正则表达式match和search用法实例
2015/03/26 Python
Django使用httpresponse返回用户头像实例代码
2018/01/26 Python
如何使用Python实现自动化水军评论
2019/06/26 Python
PyTorch中Tensor的维度变换实现
2019/08/18 Python
python中树与树的表示知识点总结
2019/09/14 Python
Python函数式编程实例详解
2020/01/17 Python
python绘制封闭多边形教程
2020/02/18 Python
如何用Python徒手写线性回归
2021/01/25 Python
CSS3+Sprite实现僵尸行走动画特效源码
2016/01/27 HTML / CSS
打印机墨盒:123Inkjets
2017/02/16 全球购物
weblogic面试题
2016/03/07 面试题
党员活动日总结
2014/05/05 职场文书
学雷锋树新风演讲稿
2014/05/10 职场文书
暑期培训心得体会
2014/09/02 职场文书
2014年重阳节老干部座谈会上的讲话稿
2014/09/25 职场文书
分析Python感知线程状态的解决方案之Event与信号量
2021/06/16 Python