最近做项目时遇到如题的问题:
页面上有2个ListBox控件 ListBox控件中间是2个左移,右移按钮,就是实现把2个 listbox 控件中的项左右移动,
为减少与服务器交互的次数,采用 javascript 脚本来控制移动, 但是这样控制以后,提交到服务器端却怎么也得不到移动数据后的实际值, 2个listbox的值和开始加载时的一样,根本改变, 不知道是什么原因, 网上有说各种原因的,我也不知道对不对,也许是自己水平有限吧, 我自己琢磨了一下,可以利用隐藏域来保存修改,然后在服务器端得到隐藏域里的value,以下是我写的客户端的代码
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>

<script type="text/javascript" language="javascript">...
function SelectOne()

...{
var listBox1=window.document.getElementById("listBox1");
var lstindex=listBox1.selectedIndex;
if(lstindex<0)
return;
var v = listBox1.options[lstindex].value;
var t = listBox1.options[lstindex].text;
var listBox2=window.document.getElementById("listBox2");
listBox2.options[listBox2.options.length] = new Option(t,v,true,true);
var hid = document.getElementById("hid");
hid.value += t + "-" + v + "|";
listBox1.remove(lstindex);
}
</script>
</head>
<body>
<form id="Form1" runat="server" action="">
<div>
<asp:ListBox ID="listBox1" runat="server">
</asp:ListBox>
<input type="button" onclick="SelectOne();" value=">>" />
<asp:ListBox ID="listBox2" runat="server">
</asp:ListBox>
</div>
<asp:Button ID="save" runat="server" OnClick="save_Click" />
<input type="hidden" runat="server" id="hid" />
</form>
</body>
</html>
我将选中的值 组合成: key1 - value1 | key2 - value2 | key3 - value3 的形式保存在hid隐藏控件的 value 上,
然后在服务器端可以 取出 hid 控件的 value 值 ,再按 "|" 进行 split 后得到 键/值 对 的数组 ,
然后再按 "-" 符号 split ,取出 key 和 value 保存在一个 hashtable 中,
注意: 保存进 hashtable 的时候 判断 如果 key 已经存在 则从 hashtable 中删除此 键/值 对,如不存在则添加
进 hashtable 中, 这样可以清除掉 hid 控件的value值中的重复项( 以上代码是无论添加项 还是移除项 总是在 hid
控件的 value 值上追加 键/值 对)