这是我用 Javascript 制作的“Dual listbox”(双向选择器)的一个应用示例,是从我的代码中抠出来的。在网页编程中经常会用到。

也许我的实现太烦琐了,希望大家有更好的代码贡献出来。

<html>

<head>

  <title>选择器</title>

  <link href="./style/style.css" rel="stylesheet" type="text/css">

  <meta http-equiv="Content-Type" content="text/html; charset=gb2312">

  <meta http-equiv="Page-Enter" content="blendTrans(Duration=1.0)">

  <meta http-equiv="Page-Exit" content="blendTrans(Duration=1.0)">

  <script language="javascript">

    function openwin(url, l, t, w ,h)

    {open(url,'','toolbar=no,location=no,status=no,menubar=no,scrollbars=no,resizable=no,width='+ w +',height='+ h +',left='+ l +',top='+ t);}

function check_and_submit(frm)

    {

      SelectAll(frm.SelectedItem);

      frm.submit();

    }

  </script>

</head>

<body>

<form name="frm1" id="frm1" method="post" action="save.asp">

<input name="allowsubmit" type="hidden" value="OK">

<table width="500" border="0" cellspacing="0" cellpadding="0" align="center">

  <tr height=10><td colspan=3></td></tr>

  <tr>

    <td width="220" align=center valign="top">

      已分配该用户管理的栏目:<br><br>

      <select name="SelectedItem" id="SelectedItem" size=12 multiple="true">

        <option>无</option>

</select>

      </select>

    </td>

    <td width="60" align=center>

      <br><br>

      <button onClick="MoveSingleItem(WaitSelectItem, SelectedItem)">&lt;</button><br><br>

      <button onClick="MoveAllItems(WaitSelectItem, SelectedItem)">&lt;&lt;</button><br><br><br><br>

      <button onClick="MoveSingleItem(SelectedItem, WaitSelectItem)">&gt;</button><br><br>

      <button onClick="MoveAllItems(SelectedItem, WaitSelectItem)">&gt;&gt;</button><br>

    </td>

    <td width="220" align=center valign="top">

      待分配的栏目:<br><br>

      <select name="WaitSelectItem" size=12 multiple=true>

        <option>师大要闻</option>

        <option>视频新闻</option>

        <option>图片新闻</option>

        <option>专题要闻</option>

        <option>十万个为什么</option>

        <option>代码测试</option>

        <option>www.why100000.com</option>

      </select>

    </td>

  </tr>

</table>

</form>

<script language="javascript">

 function MoveSingleItem(sel_source, sel_dest)

 {

   if (sel_source.selectedIndex==-1)  //源:没有点选任何项目

     return;

if (sel_source.options[0].text=="无") //源:只有“无”项目

     return;

if (sel_dest.options[0].text=="无") //目标:只有“无”项目,则先删除该提示性项目

     sel_dest.options.remove(0);

var SelectedText = sel_source.options[sel_source.selectedIndex].text;

   sel_dest.options.add(new Option(SelectedText));

   sel_source.options.remove(sel_source.selectedIndex);

if (sel_source.options.length==0)  //源:如果删除完所有有用项目,则添加提示项目:“无”

     sel_source.options.add(new Option("无"));

 }

function MoveAllItems(sel_source, sel_dest)

 {

   if (sel_source.options[0].text=="无") //源:只有“无”项目

     return;

if (sel_dest.options[0].text=="无")   //目标:只有“无”项目,则先删除该提示性项目

     sel_dest.options.remove(0);

//首先拷贝所有项目到目标:

   var sel_source_len = sel_source.length;

   for (var j=0; j<sel_source_len; j++)

   {

     var SelectedText = sel_source.options[j].text;

     sel_dest.options.add(new Option(SelectedText));

   }

//然后删除“源”所有项目:

   while ((k=sel_source.length-1)>=0)

   {

     if (sel_source.options[0].text=="无") //源:只有“无”项目

       break;

     sel_source.options.remove(k);

     if (sel_source.options.length==0)  //源:如果删除完所有有用项目,则添加提示项目:“无”

       sel_source.options.add(new Option("无"));

   }

 }

function SelectAll(theSel)  //选中select中全部项目

 { for (i = 0 ;i<theSel.length;i++)

    theSel.options[i].selected = true;

 }

</script>

用 Javascript 实现的“Dual listbox”(双向选择器)的更多相关文章

  1. jquery 双向select控件bootstrap Dual listbox

    http://www.cnblogs.com/hangwei/p/5040866.html       -->jquery 双向select控件bootstrap Dual listboxhtt ...

  2. 前端插件之Bootstrap Dual Listbox使用

    工欲善其事,必先利其器 对于很多非专业前端开发来说写页面是非常痛苦的,借助框架或插件往往能够达到事半功倍的效果,本系列文章会介绍我在运维系统开发过程中用到的那些顺手的前端插件,如果你是想写XX管理系统 ...

  3. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  4. 五十行javascript代码实现简单的双向数据绑定

    五十行javascript代码实现简单的双向数据绑定 Vue框架想必从事前端开发的同学都使用过,它的双向数据绑定机制能给我们带来很大的方便.今天闲着没事,尝试着实现一下双向数据绑定,接下来给大家分享一 ...

  5. Jquery双向select控件Bootstrap Dual Listbox

    效果预览: 一. 下载插件 github地址:https://github.com/istvan-ujjmeszaros/bootstrap-duallistbox 也可以在这个网站中下载:http: ...

  6. JavaScript 数字转汉字+element时间选择器快速选择

    window.CN = { : '一', : '二', : '三', : '四', : '五', : '六', : '七', : '八', : '九', : '零' } window.LEVEL = ...

  7. jQ选择器学习片段(JavaScript 部分对应)

    $()函数在大多的JavaScript类库中都被作为一个选择器函数来使用,在jQuery中就是. $("#id")通过id来获取元素,用来代替document.getElement ...

  8. JavaScript实现简单的双向数据绑定

    什么是双向数据绑定 双向数据绑定简单来说就是UI视图(View)与数据(Model)相互绑定在一起,当数据改变之后相应的UI视图也同步改变.反之,当UI视图改变之后相应的数据也同步改变. 双向数据绑定 ...

  9. 第一百三十九节,JavaScript,封装库--CSS选择器

    JavaScript,封装库--修改元素选择器 就是将构造库函数修改成元素选择器,像css那样,输入#xxx .xxx xxx  (获取指定id下的指定class下的指定标签元素) 修改后的基础库 / ...

随机推荐

  1. 《java入门第一季》之集合框架TreeSet存储元素自然排序以及图解

    这一篇对TreeSet做介绍,先看一个简单的例子: * TreeSet:能够对元素按照某种规则进行排序.  * 排序有两种方式  * A:自然排序: 从小到大排序  * B:比较器排序    Comp ...

  2. 《java入门第一季》之集合框架(Collection小儿子Set集合)

    /*  * Collection主要的连个儿子:  * |--List  * 有序(存储顺序和取出顺序一致),可重复  * |--Set  * 无序(存储顺序和取出顺序不一致),唯一  *   * H ...

  3. 求解n皇后

    要求:在国际象棋上摆放n个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同一列或同一斜线上,问有多少种摆法 思路:很直观的想法就是在棋盘上一个一个皇后的摆,如果冲突,则摆放在另一个位置,直至 ...

  4. Spark MLlib数据类型

        MLlib支持几种数据类型:本地向量(local vectors),和存储在一个简单机器中的矩阵(matrices),以及由一个或多个RDDs组成的分布式矩阵. 1,本地向量(Local Ve ...

  5. MO_GLOBAL - EBS R12 中 Multi Org 设计的深入研究 (2)

    这是多组织访问的第二篇文章,翻译自Anil Passi的Multi Org R12 我们都知道,在Oracle Release 12中多组织模型(Multi Org)会被改变, 它被叫作多组织访问控制 ...

  6. 13_Android的生命周期

     Activity的生命周期图 2 Android生命周期中涉及到的几个过程 1.启动Activity:系统会先调用onCreate方法,然后调用onStart方法,最后调用onResume,Ac ...

  7. Leetcode_172_Factorial Trailing Zeroes

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/42417535 Given an integer n, re ...

  8. MPLSVPN 命令集

      载请标明出处:http://blog.csdn.net/sk719887916,作者:skay 读懂下面配置命令需要有一定的TCP/IP,路由协议基础,现在直接上关键VPN命令. router ...

  9. 基于Retrofit2.0+RxJava+Dragger2实现不一样的Android网络构架搭建(转载)

    转载请注明出处:http://blog.csdn.net/finddreams/article/details/50849385#0-qzone-1-61707-d020d2d2a4e8d1a374a ...

  10. Windows200864位操作系统下的SQLPLUS.EXE 无法找到入口解决办法和Oracle环境变量的设置

    本机环境:Windows2008 64位中文版操作系统+Oracle11G+安装了Oracle32位和64位客户端驱动 问题起源:Path环境变量被360安全卫士优化修复后,整个给清空了,hosts文 ...