我所做的一件事是在会话中通过 AJAX 记录检查的状态,然后在回发(通过 AJAX 的全部或部分)上,在会话中查找要执行所选操作的项目。
基本思想是在复选框中添加一个 onclick 处理程序,该处理程序知道关联项目的 id。在点击处理程序中,通过 AJAX 将此 id 传回服务器并将其记录在会话中——您还需要传达复选框状态,以便您可以取消选中项目。让提交控件的处理程序使用有关从会话中选择了哪些项目的数据。
这种方式也允许您处理分页数据,因为您可以在呈现(完整或部分)带有选中项目的页面时从会话中设置复选框的初始值。
它可能看起来像这样。假设 ASP.NET AJAX 带有 PageMethods(当然还有 ScriptManager)。
<script type='text/javascript'>
function record(checkbox,item)
{
var context = { ctl : checkbox };
PageMethods.Record(item,checkbox.checked,onSuccess,onFailure,context);
}
function onSuccess(result,context)
{
// do something, maybe highlight the row, maybe nothing
}
function onFailure(error,context)
{
context.ctl.checked = false;
alert(error.get_Message());
}
</script>
...
<tr><td><input type='checkbox' onclick='record(this,"item_1");'></td><td>Item 1</td></tr>
...
Codebehind
[WebMethod(EnableSessionState=true)]
public static void Record( string itemName, bool value )
{
List<string> itemList = (List<string>)Session["Items"];
if (itemList == null)
{
itemList = new List<string>();
Session["Items"] = itemList;
}
if (itemList.Contains(itemName) && !value)
{
itemList.Remove(itemName);
}
else if (!itemList.Contains(itemName) && value)
{
itemList.Add(itemName);
}
}
protected void button_OnClick( object sender, EventArgs e )
{
List<string> itemList = (List<string>)Session["Items"];
if (itemList != null)
{
foreach (string item in itemList)
{
// do something with the selected item
}
}
}