jquery制作select列表双向选择

系统 2404 0

    做项目的时候要用到的一个小功能,以前做过的,用的纯JS,今天翻出来看发现只能在IE中运行的,自己改成jquery的了,该功能很常见,不过一直不知道他的学名叫什么,所以也就随便起个了,大家看下面的图都应该知道了:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>select列表双向选择</title>
    <style type="text/css">
        select
        {
            width: 100%;            
            height: 160px;
        }
        div
        {
            float: left;
        }
        #div1, #div3
        {
            width: 150px;
        }
        #div2
        {
            width: 120px;
        }
        .btn
        {
            display: block;
            margin: 10px auto;
            width: 80px;
        }
    </style>
</head>
<body>
    <div id="div1">
        <select id="dltSource" name="dltSource" size="10" multiple="multiple">
            <option value="苹果">苹果</option>
            <option value="雪梨">雪梨</option>
            <option value="西瓜">西瓜</option>
            <option value="荔枝">荔枝</option>
            <option value="龙眼">龙眼</option>
            <option value="香蕉">香蕉</option>
        </select>
    </div>
    <div id="div2">
        <input type="button" value="&gt;" class="btn" onclick="Add($('#dltSource'),$('#dltTarget'))" />
        <input type="button" value="&gt;&gt;" class="btn" onclick="AddAll($('#dltSource'),$('#dltTarget'))" />
        <input type="button" value="&lt;" class="btn" onclick="Add($('#dltTarget'),$('#dltSource'))" />
        <input type="button" value="&lt;&lt;" class="btn" onclick="AddAll($('#dltTarget'),$('#dltSource'))" />
    </div>
    <div id="div3">
        <select id="dltTarget" name="dltTarget" size="10" multiple="multiple">
        </select>
    </div>
</body>
</html>

<script src="js/jquery.js" type="text/javascript"></script>

<script type="text/javascript">
    /* 添加选择的项 */
    function Add(ObjSource, ObjTarget) {
       if(ObjSource.val() ==null) return;    // 如果没有选择则退出函数,无这句话的话IE6会报错
        $.each(ObjSource.val(), function(i, n) {    // 循环原列表中选中的值,依次添加到目标列表中
            var html = "<option value='" + n + "'>" + n + "</option>";
            ObjTarget.append(html);
        });
        ObjSource.find("option:selected").remove();  // 原列表中选中的值删除
    }
    /* 添加全部 */
    function AddAll(ObjSource, ObjTarget) {
        ObjTarget.append(ObjSource.html());  // 目标列表的HTML加上原列表的所有HTML
        ObjSource.empty();  // 原列表清空
    }
</script>

  
 

jquery制作select列表双向选择


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论