两个select来回联动

在两个select中来回切换option的实现
示例

0.HTML

    <select multiple="multiple" id="sel1">
        <option value="1">ABC</option>
        <option value="2">DEF</option>
        <option value="3">GHI</option>
        <option value="4">LMN</option>
        <option value="5">OPQ</option>
    </select>
    <!--另一个select类似-->

1.双击切换:注意要用动态生成用on事件绑定!


    $("#sel1").on("dblclick","option", function ()
    {
        $("#sel2").append($(this)); // apend会移动到目标父元素上
        selSort(2);
    });

    $("#sel2").on("dblclick","option", function () {
        $("#sel1").append($(this));
        selSort(1);
    });

2.按钮切换:可以多选

     $("#btnAdd").click(function ()   //单击 “加入”后
    { 
        var isSelected = $("#sel1>option:selected");      //
        //console.log(isSelected);
        $("#sel2").append(isSelected);
        selSort(2);
    });            //“删除”类似

3.option排序:每一次切换都重新排序

     function selSort(i)
    {

        $("#sel" + i + ">option").sort(function (a, b)
        {
            var aText = $(a).text().toUpperCase();
            var bText = $(b).text().toUpperCase();
            if (aText > bText) return 1;
            if (aText < bText) return -1;
            //console.log(aText,bText);
            //return 0;
        }).appendTo("#sel" + i);
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现两个select联动,可以使用JavaScript来实现。具体步骤如下: 1. 给第一个select添加一个onchange事件,在该事件中获取选中的值。 2. 根据第一个select选中的值,动态生成第二个select的选项。 3. 将生成的选项添加到第二个select中。 以下是示例代码: ```html <!-- 第一个select --> <select id="select1" onchange="changeSelect()"> <option value="1">选项1</option> <option value="2">选项2</option> <option value="3">选项3</option> </select> <!-- 第二个select --> <select id="select2"> </select> <script> function changeSelect() { // 获取第一个select选中的值 var select1Value = document.getElementById("select1").value; // 根据选中的值生成第二个select的选项 var select2Options = ""; if (select1Value == "1") { select2Options += "<option value='1-1'>选项1-1</option>"; select2Options += "<option value='1-2'>选项1-2</option>"; } else if (select1Value == "2") { select2Options += "<option value='2-1'>选项2-1</option>"; select2Options += "<option value='2-2'>选项2-2</option>"; } else if (select1Value == "3") { select2Options += "<option value='3-1'>选项3-1</option>"; select2Options += "<option value='3-2'>选项3-2</option>"; } // 将生成的选项添加到第二个select中 document.getElementById("select2").innerHTML = select2Options; } </script> ``` 在上面的代码中,我们给第一个select添加了一个onchange事件,并定义了一个changeSelect函数。当第一个select的选项发生改变时,changeSelect函数会被调用。 在changeSelect函数中,我们首先获取了第一个select选中的值,然后根据选中的值生成了第二个select的选项。最后,我们将生成的选项添加到第二个select中。这样,就实现了两个select联动
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值