Select multiple多选上移、下移

Select multiple多选上移、下移

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<TITLE> Select Demo </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>
<style>
    center
    {
        font-size:12px;
        color:red;
        font-weight:bold;
    }
    select
    {
        font-size:12px;
        color:green;
    }
</style>

<BODY>
    <span id='feedback'></span>
    
    <form method="post" name="myform">
  <table border="0" width="400">
 <tr>
  <td><CENTER>可选择排序方式</CENTER></td>
  <td> </td>
  <td><CENTER>已选择排序方式</CENTER></td>
 </tr>
    <tr>
      <td width="40%">
  <select  multiple name="left" id="left" size="8" style='width:200;'
  ondblclick="moveOption(document.getElementById('left'), document.getElementById('right'))">
       <option value="20">测试数据一</option>
       <option value="30">测试数据二</option>
       <option value="40">测试数据三</option>
       <option value="50">测试数据四</option>
       <option value="60">测试数据五</option>
       <option value="70">测试数据六</option>  
       <option value="80">测试数据七</option>
       <option value="90">测试数据八</option>  

  </select>
   </td>
      <td width="20%" align="center">
  <input type="button" value=" >> " οnclick="moveOption(document.getElementById('left'),document.getElementById('right'))"><br><br>
  <input type="button" value=" << " οnclick="dropOption(document.getElementById('right'))">
   </td>
      <td width="40%">
  <select  multiple name="right" id="right" size="8" style='width:200;'
  ondblclick="dropOption(document.getElementById('right'))">
  </select>
   </td>
    </tr>
<tr>
<td colspan="3"><CENTER>
    <INPUT TYPE="button" value="置顶" οnclick="moveTop(document.getElementById('right'));">
    <INPUT TYPE="button" value="上移" οnclick="moveUp(document.getElementById('right'));">
    <INPUT TYPE="button" value="下移" οnclick="moveDown(document.getElementById('right'));">
    <INPUT TYPE="button" value="置底" οnclick="moveBottom(document.getElementById('right'));">
</CENTER></td>
</tr>
  </table>
    
 
</BODY>
</HTML>


<SCRIPT LANGUAGE="JavaScript">
<!--
    //上移
    function moveUp(obj){
        for(var i=1; i < obj.options.length; i++){
   //最上面的一个不需要移动,所以直接从i=1开始
            if(obj.options[i].selected){
                if(!obj.options.item(i-1).selected){
                    var selText = obj.options[i].text;
                    var selValue = obj.options[i].value;
                    obj.options[i].text = obj.options[i-1].text;
                    obj.options[i].value = obj.options[i-1].value;
                    obj.options[i].selected = false;
                    obj.options[i-1].text = selText;
                    obj.options[i-1].value = selValue;
                    obj.options[i-1].selected=true;
                }
            }
        }
    }
    
    //下移
    function moveDown(obj){
        for(var i = obj.options.length -2 ; i >= 0; i--){
   //向下移动,最后一个不需要处理,所以直接从倒数第二个开始
            if(obj.options[i].selected){
                if(!obj.options[i+1].selected){
                    var selText = obj.options[i].text;
                    var selValue = obj.options[i].value;
                    obj.options[i].text = obj.options[i+1].text;
                    obj.options[i].value = obj.options[i+1].value;
                    obj.options[i].selected = false;
                    obj.options[i+1].text = selText;
                    obj.options[i+1].value = selValue;
                    obj.options[i+1].selected=true;
                }
            }
        }
    }
    
    //移动
    function moveOption(obj1, obj2){
        for(var i = obj1.options.length - 1 ; i >= 0 ; i--){
            if (obj2.options.length > 0){
                var exsits = false;
                for (var j = 0; j < obj2.options.length; j ++ ){
                    if (obj2.options[j].value == obj1.options[i].value){
                        exsits = true;
                        break;
                    }
                }
                if(exsits){
                    continue;
                }
            }
            if(obj1.options[i].selected){
                var opt = new Option(obj1.options[i].text,obj1.options[i].value);
                opt.selected = true;
                obj2.options.add(opt);
                //obj1.remove(i);
            }
        }
    }
    
    //删除
    function dropOption(obj){
        for(var i = obj.options.length - 1 ; i >= 0 ; i--){
            if(obj.options[i].selected){
                obj.remove(i);
            }
        }
    }
    
    //置顶
    function  moveTop(obj){ 
        var opts = []; 
        for(var i =obj.options.length -1 ; i >= 0; i--){
            if(obj.options[i].selected){
                opts.push(obj.options[i]);
                obj.remove(i);
            }
        }
        var index = 0 ;
        for(var t = opts.length-1 ; t>=0 ; t--){
            var opt = new Option(opts[t].text,opts[t].value);
            opt.selected = true;
            obj.options.add(opt, index++);
        }
    } 
    //置底
    function  moveBottom(obj){ 
        var opts = []; 
        for(var i =obj.options.length -1 ; i >= 0; i--){
            if(obj.options[i].selected){
                opts.push(obj.options[i]);
                obj.remove(i);
            }
        }
        for(var t = opts.length-1 ; t>=0 ; t--){
            var opt = new Option(opts[t].text,opts[t].value);
            opt.selected = true;
            obj.options.add(opt);
        }
    }

    //-->
</SCRIPT>

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113502.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • propertydescriptor是用来干什么的_constructor java

    propertydescriptor是用来干什么的_constructor java1、PropertyDescriptor简述PropertyDescriptor对象是位于java.beans包下的工具类,顾名思义为属性描述器,通常我们用于通过反射获取对象方法的时候,下面来看一下常用的用法吧!2、PropertyDescriptor用法(1)、给你一个java对象,你如何生成PropertyDescriptor对象呢?通常,我们会用到…

    2022年10月1日
    4
  • (十一)模仿学习

    (十一)模仿学习  从之前的讨论看,都是有奖励的。哪怕是上一章的稀疏奖励,其实也有奖励。==假如任何奖励都没有怎么办?==本章介绍的就是这种情况的解决办法。什么时候任何奖励都没有。其实还挺常见的,以聊天机器人为例,聊的好不好很难定义奖励。解决这种情况的方法就是模仿学习  模仿学习(imitationlearning),有时也叫示范学习或者学徒学习。指有一些专家的示范,通过模仿这些专家来达到目的。专家的示范含义很广,比如在自动驾驶中,一个司机的行为就可以被称为专家的示范。  模仿学习中主要有两个方法:行为克隆和逆强化

    2026年1月26日
    4
  • kubeadm部署高可用kubernetes

    kubeadm部署高可用kubernetes1准备环境(所有主机执行)1.1主机列表cat>>/etc/hosts<<EOF192.168.3.71k8s-master01192.168.3.72k8s-master02192.168.3.73k8s-master03192.168.3.74k8s-worker01192.168.3.75k8s-worker02192.168.3.76k8s-worker03192.168.3.77k8s-worker04

    2022年7月25日
    9
  • dsp指令ixh_C24XX系列DSP移位指令总结[通俗易懂]

    dsp指令ixh_C24XX系列DSP移位指令总结[通俗易懂]C24XX系列DSP移位指令总结徐丽红王佰营TI公司C24XX系列DSP的移位指令很有特色而且效率很高;一般的移位功能不用专门的指令实现而是作为其他指令中的一个功能给出,并且移位并不占用CPU额外时间。以下整理出了DSP常用的移位指令:一、两类移位指令1>显性移位指令,移位次数由指令直接给出:1add—sub←0—162and—or—xor←#L3lacc←0—164sach—sacl←…

    2022年5月18日
    67
  • 猴子分苹果问题递归算法_猴子分苹果递推公式

    猴子分苹果问题递归算法_猴子分苹果递推公式试题算法训练猴子分苹果题目描述:资源限制时间限制:1.0s内存限制:256.0MB问题描述  秋天到了,n只猴子采摘了一大堆苹果放到山洞里,约定第二天平分。这些猴子很崇拜猴王孙悟空,所以都想给他留一些苹果。第一只猴子悄悄来到山洞,把苹果平均分成n份,把剩下的m个苹果吃了,然后藏起来一份,最后把剩下的苹果重新合在一起。这些猴子依次悄悄来到山洞,都做同样的操作,恰好每次都剩下了m个…

    2022年10月12日
    4
  • vue中使用animate css

    vue中使用animate cssvue2使用animatecss安装安装的方式有很多种1.在html文件中直接引用从github上下载的资源&lt;linkrel="stylesheet"href="vue2-animate.min.css"&gt;2.如果使用webpack并且用对了css-loader可以使用npm安装npm安装包依赖npminstall–savevue2-animate3…

    2022年7月27日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号