论坛首页 Web前端技术论坛

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

浏览 17209 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2008-10-30  

两个select,将其中一个select选中的选项添加到另一个select中,或者点击全部添加按钮将所有的option都添加过去.
自己写了一个很简单的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() {
				$("<option></option>")
				.val($(this).val())
				.text($(this).text())
				.appendTo($("#"+toid+":not(:has(option[value="+$(this).val()+"]))"));
			});
		}
		else if(isAll == false) {
			$("#"+fromid+" option:selected").each(function() {
				$("<option></option>")
				.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()+"]))"));
		});
	}
};
 

测试页面(listtolist.html)

<html>
<head>
	<script src="jquery.js"></script>
	<script src="listtolist.js"></script>
	<script type="text/javascript">
		$(document).ready(function() {
			$("#select1").dblclick(function() {$.listTolist("select1","select2","move",false);});
			$("#select2").dblclick(function() {$.listTolist("select2","select1","move",false);});
			$("#moveright").click(function() {$.listTolist("select1","select2","move",false);});
			$("#moverightall").click(function() {$.listTolist("select1","select2","move",true);});
			$("#moveleft").click(function() {$.listTolist("select2","select1","move",false);});
			$("#moveleftall").click(function() {$.listTolist("select2","select1","move",true);});
			
			$("#select3").dblclick(function() {$.listTolist("select3","select4","append",false);});
			$("#select4").dblclick(function() {$.listTolist("select4","select3","append",false);});
			$("#appendright").click(function() {$.listTolist("select3","select4","append",false);});
			$("#appendrightall").click(function() {$.listTolist("select3","select4","append",true);});
			$("#appendleft").click(function() {$.listTolist("select4","select3","append",false);});
			$("#appendleftall").click(function() {$.listTolist("select4","select3","append",true);});
			
			$("#select5").dblclick(function() {$.list2list("select5","select6",false);});
			$("#select6").dblclick(function() {$.list2list("select6","select5",false);});
			$("#transright").click(function() {$.list2list("select5","select6",false);});
			$("#transrightall").click(function() {$.list2list("select5","select6",true);});
			$("#transleft").click(function() {$.list2list("select6","select5",false);});
			$("#transleftall").click(function() {$.list2list("select6","select5",true);});
		});
	</script>
</head>
<body>
<form action="#" method="post">
	<p>移动(move)测试:</p>
	<label for="select1">select1</label>
	<select id="select1" style="width:100px" size="5" multiple="true">
		<option value="1">number 1</option>
		<option value="2">number 2</option>
		<option value="3">number 3</option>
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
		<option value="7">number 7</option>
		<option value="8">number 8</option>
		<option value="9">number 9</option>
		<option value="10">number 10</option>
		<option value="11">number 11</option>
	</select>
	<label for="select2">select2</label>
	<select id="select2" style="width:100px" size="5" multiple="true">
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
	</select>
	<br />
	<button id="moveright">右移</button>
	<button id="moverightall">全部右移</button>
	<button id="moveleft">左移</button>
	<button id="moveleftall">全部左移</button>
	<hr />
	<p>追加(append)测试:</p>
	<label for="select3">select3</label>
	<select id="select3" style="width:100px" size="5" multiple="true">
		<option value="1">number 1</option>
		<option value="2">number 2</option>
		<option value="3">number 3</option>
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
		<option value="7">number 7</option>
		<option value="8">number 8</option>
		<option value="9">number 9</option>
		<option value="10">number 10</option>
		<option value="11">number 11</option>
	</select>
	<label for="select4">select4</label>
	<select id="select4" style="width:100px" size="5" multiple="true">
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
	</select>
	<br />
	<button id="appendright">右移</button>
	<button id="appendrightall">全部右移</button>
	<button id="appendleft">左移</button>
	<button id="appendleftall">全部左移</button>
	<hr />
	<p>list2list测试:</p>
	<label for="select5">select5</label>
	<select id="select5" style="width:100px" size="5" multiple="true">
		<option value="1">number 1</option>
		<option value="2">number 2</option>
		<option value="3">number 3</option>
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
		<option value="7">number 7</option>
		<option value="8">number 8</option>
		<option value="9">number 9</option>
		<option value="10">number 10</option>
		<option value="11">number 11</option>
	</select>
	<label for="select6">select6</label>
	<select id="select6" style="width:100px" size="5" multiple="true">
		<option value="4">number 4</option>
		<option value="5">number 5</option>
		<option value="6">number 6</option>
	</select>
	<br />
	<button id="transright">右移</button>
	<button id="transrightall">全部右移</button>
	<button id="transleft">左移</button>
	<button id="transleftall">全部左移</button>
</form>
</body>
</html>
 
   发表时间:2009-02-19  
谢谢,我试了试,在IE下正常,但在FireFox下有问题.
0 请登录后投票
   发表时间:2009-02-19  
同样用jquery,实现同样的功能,我这样……

function transferOption(sourceId,targetId){
var target = $("#"+targetId);
target.append($("option[@selected]", $("#"+sourceId)));
} 


sourceId源下拉框id,targetId要转移到的下拉框id……
不知楼主怎么那么麻烦……
0 请登录后投票
   发表时间:2009-02-20  
tianhaoleng 写道
同样用jquery,实现同样的功能,我这样……

function transferOption(sourceId,targetId){
var target = $("#"+targetId);
target.append($("option[@selected]", $("#"+sourceId)));
} 


sourceId源下拉框id,targetId要转移到的下拉框id……
不知楼主怎么那么麻烦……

1.如果要将一个select中的option全部移动到另一个select中去,你这种实现方式必须先将原select中的所有元素全部选中后才能移动过去,而且如果原select每次只能选定一个的话那就更不能实现了。
2.你将原select中的option直接添加到目标select中,那如果目标select中已经有了这个option怎么处理呢?
3.请帮我解释下
target.append($("option[@selected]", $("#"+sourceId)))
这句话吧,我没看懂这个语法.
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics