select标签左边集合和右边集合 ,添加,移除, 多选添加,移除功能
2016-09-13 11:45
489 查看
代码直接复制可运行:
<%-- Created by IntelliJ IDEA. User: Freddy Date: 2016/9/13 Time: 10:28 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> </head> <SCRIPT LANGUAGE="JavaScript"> <!-- //上移 function moveUp(obj) { for(var i=1; i < obj.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.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(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 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); } } //置顶 function saveButton(obj) { alert("暂时没有做:TODO"); } //--> </SCRIPT> <body> <span id='feedback'></span> <form method="post" name="myform"> <table border="0" width="400"> <tr> <td><CENTER>可选择车辆信息</CENTER></td> <td> </td> <td><CENTER>要添加到的上海金桥4S围栏</CENTER></td> </tr> <tr> <td width="40%"> <select multiple name="left" id="left" size="6" 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="添加(可全选)" onclick="moveOption(document.getElementById('left'),document.getElementById('right'))"> <input type="button" value="移除(可全选)" onclick="moveOption(document.getElementById('right'), document.getElementById('left'))"> </td> <td width="40%"> <select multiple name="right" id="right" size="6" style='width:200;' ondblclick="moveOption(document.getElementById('right'), document.getElementById('left'))"> </select> </td> </tr> <tr> <td colspan="3"> <CENTER> <INPUT TYPE="button" value="保存" onclick="saveButton(document.getElementById('right'));"> <INPUT TYPE="button" value="取消" onclick="moveOption(document.getElementById('right'), document.getElementById('left'))"> </CENTER></td> </tr> <%-- <tr> <td colspan="3"> <CENTER> <INPUT TYPE="button" value="置顶" onclick="moveTop(document.getElementById('right'));"> <INPUT TYPE="button" value="上移" onclick="moveUp(document.getElementById('right'));"> <INPUT TYPE="button" value="下移" onclick="moveDown(document.getElementById('right'));"> <INPUT TYPE="button" value="置底" onclick="moveBottom(document.getElementById('right'));"> </CENTER></td> </tr>--%> </table> </body> </html>
相关文章推荐
- 左边select内容选择到右边select内容里面的js实现方法(可以多选和全选)
- 操作TreeView:,选中左边树的节点,点击>>按钮 将选择的节点展现到右边的树中,同时将选择的节点从左边的树中移除。。点击<<实现同样的功能。。。。
- 左边select内容选择到右边select内容里面的js实现方法(可以多选和全选)
- JS左边select内容选择到右边select内容里面的js实现方法(可以多选和全选)
- Struts2 <s:select>标签 的 多选功能
- 左边select内容选择到右边select内容里面的js实现方法(可以多选和全选)
- 左边select添加到右边select框
- Display标签功能扩展--添加列宽调整功能
- javascript如何动态添加附带移除功能的行
- 多选列表Select之双击删除与添加Demo
- javscript操作Select标签[动态添加,清空]
- select 多选 左右框添加删除
- JQuery 实现多选 select 的增加与移除效果_Jian
- flex中移除由MXML标签添加的侦听
- struts2 select标签对Action中传递过来的List集合生成下拉列表
- 两侧SELECT列表值的添加与移除
- HTML中select标签如何添加子项的标题
- JQuery快速添加/移除插件EasyInsert的简单取值、自动添加或移除多行标签、自动添加事件
- 两个Select标签内容多选切换之jquery方法
- 移除由MXML标签添加的侦听