首页 > web前端 > js教程 > 两个select之间option的互相添加操作(jquery实现)_jquery

两个select之间option的互相添加操作(jquery实现)_jquery

WBOY
发布: 2016-05-16 18:41:52
原创
1252 人浏览过

自己写了一个很简单的jquery插件,在页面中调用其中的函数就可实现.
插件源代码(listtolist.js):

复制代码 代码如下:

/**
fromid:源list的id.
toid:目标list的id.
moveOrAppend参数("move"或者是"append"):
move -- 源list中选中的option会删除.源list中选中的option移动到目标list中,若目标list中已存在则该option不添加.
append -- 源list中选中的option不会删除.源list中选中的option添加到目标list的后面,若目标list中已存在则该option不添加.

isAll参数(true或者false):是否全部移动或添加
*/
jQuery.listTolist = function(fromid,toid,moveOrAppend,isAll) {
    if(moveOrAppend.toLowerCase() == "move") {    //移动
        if(isAll == true) {    //全部移动
            $("#" fromid " option").each(function() {
                //将源list中的option添加到目标list,当目标list中已有该option时不做任何操作.
                $(this).appendTo($("#" toid ":not(:has(option[value=" $(this).val() "]))"));
            });
            $("#" fromid).empty();    //清空源list
        }
        else if(isAll == false) {
            $("#" fromid " option:selected").each(function() {
                //将源list中的option添加到目标list,当目标list中已有该option时不做任何操作.
                $(this).appendTo($("#" toid ":not(:has(option[value=" $(this).val() "]))"));
                //目标list中已经存在的option并没有移动,仍旧在源list中,将其清空.
                if($("#" fromid " option[value=" $(this).val() "]").length > 0) {
                    $("#" fromid).get(0)
                    .removeChild($("#" fromid " option[value=" $(this).val() "]").get(0));
                }
            });
        }
    }
    else if(moveOrAppend.toLowerCase() == "append") {
        if(isAll == true) {
            $("#" fromid " option").each(function() {
                $("")
                .val($(this).val())
                .text($(this).text())
                .appendTo($("#" toid ":not(:has(option[value=" $(this).val() "]))"));
            });
        }
        else if(isAll == false) {
            $("#" fromid " option:selected").each(function() {
                $("")
                .val($(this).val())
                .text($(this).text())
                .appendTo($("#" toid ":not(:has(option[value=" $(this).val() "]))"));
            });
        }
    }
};
/**
功能大体同上("move").
不同之处在于当源list中的选中option在目标list中存在时,源list中的option不会删除.

isAll参数(true或者false):是否全部移动或添加
*/
jQuery.list2list = function(fromid,toid,isAll) {
    if(isAll == true) {
        $("#" fromid " option" ).each(function() {
            $(this).appendTo($("#" toid ":not(:has(option[value=" $(this).val() "]))") );
        });
    }
    else if(isAll == false) {
        $("#" fromid " option:selected").each(function() {
            $(this).appendTo($( "#" toid ":not(:has(option[value=" $(this).val() "]))"));
        });
    }
};

预算下载
相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板