自己写了一个很简单的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()+"]))")); }); } };
打包下载