在服务器端得到CheckBoxList控件最后选择项的方法!

转载 2007年09月24日 12:46:00

探讨这个问题的起因是CSDN论坛的一个帖子:

http://community.csdn.net/Expert/TopicView.asp?id=5460832

 查看客户端生成的HTML代码可以看出,每次点击都执行一次__doPostBack,并且将选择项的参数传递到隐藏表单域之中。 当然,通过脚本和自己的隐藏域可以很轻松得到选择项,但完全在服务器端,也可以得到。

<form name="MengXianhui" method="post" action="a.aspx?ddfg" id="MengXianhui">
<input type="hidden" name="__EVENTTARGET" value="" />
<input type="hidden" name="__EVENTARGUMENT" value="" />
<input type="hidden" name="__VIEWSTATE" value="dDw0NjI1MDk1MzQ7O2w8Q2hlY2tCb3hMaXN0MTowO0NoZWNrQm94TGlzdDE6MTtDaGVja0JveExpc3QxOjI7Q2hlY2tCb3hMaXN0 MTozO0NoZWNrQm94TGlzdDE6NDtDaGVja0JveExpc3QxOjQ7Pj6h9p2gvuU8iLKlA4DU0GtLAoZhCw==" />

<script language="javascript" type="text/javascript">
<!--
    
function __doPostBack(eventTarget, eventArgument) {
        
var theform;
        
if  (window.navigator.appName.toLowerCase().indexOf("microsoft")  > -1)  {
            theform 
= document.MengXianhui;
        }
        
else {
            theform 
= document.forms["MengXianhui"];
        }
        theform.__EVENTTARGET.value 
= eventTarget.split("$").join(":");
        theform.__EVENTARGUMENT.value 
= eventArgument;
        theform.submit();
    }
// -->
</script>

  
<div style="padding:20px">
    
<table id="CheckBoxList1" border="0">
    
<tr>
        
<td><input id="CheckBoxList1_0" type="checkbox" name="CheckBoxList1:0" onclick="__doPostBack('CheckBoxList1$0','') " language="javascript" /><label for="CheckBoxList1_0">a</label></td>
    
</tr><tr>
        
<td><input id="CheckBoxList1_1" type="checkbox" name="CheckBoxList1:1" onclick="__doPostBack('CheckBoxList1$1','')" language="javascript" /><label for="CheckBoxList1_1">b</label></td>
    
</tr><tr>
        
<td><input id="CheckBoxList1_2" type="checkbox" name="CheckBoxList1:2" checked="checked" onclick="__doPostBack('CheckBoxList1$2','') " language="javascript" /><label for="CheckBoxList1_2">c</label></td>
    
</tr><tr>
        
<td><input id="CheckBoxList1_3" type="checkbox" name="CheckBoxList1:3" checked="checked" onclick="__doPostBack('CheckBoxList1$3','')" language="javascript" /><label for="CheckBoxList1_3">d</label></td>
    
</tr><tr>
        
<td><input id="CheckBoxList1_4" type="checkbox" name="CheckBoxList1:4" onclick="__doPostBack('CheckBoxList1$4','') " language="javascript" /><label for="CheckBoxList1_4">e</label></td>
    
</tr>
</table>
    
</div>
   
  
</form>

在服务器端得到选择项的做法是分析事件的参数,通过提交过来的事件参数得到。代码如下:

<%@ Page Language="C#" AutoEventWireup="true" EnableViewState="false" Debug="true" % >
<!DOCTYPE html PUBLIC " -//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1- transitional.dtd">
<script runat="server">
void BoxList1_SelectedIndexChanged(object sender, System.EventArgs e)
{
//得到触发事件的选择项
string ClickedItem = Request.Form["__EVENTTARGET"];
ClickedItem 
= ClickedItem.Split(':')[1];
int index = Int32.Parse(ClickedItem );
Response.Write(CheckBoxList1.Items [index].Text);
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  
<title>在服务器端得到CheckBoxList 最好所选择项的方法</title>
</head>
<body>
  
<form id="MengXianhui" runat="server">
  
<div style="padding:20px">
    
<asp:CheckBoxList AutoPostBack="true" ID="CheckBoxList1" runat="server"
     OnSelectedIndexChanged
="BoxList1_SelectedIndexChanged">
    
<asp:ListItem Value="1">a</asp:ListItem>
    
<asp:ListItem>b</asp:ListItem>
    
<asp:ListItem>c</asp:ListItem>
    
<asp:ListItem>d</asp:ListItem>
    
<asp:ListItem>e</asp:ListItem>
    
</asp:CheckBoxList>
    
</div>   
  
</form>
</body>
</html>
 

相关文章推荐

ios开发 之 UIPickerView控件,UI关联选择项如何处理

当选择左边的一级选项时,左边展示一级选项里含有的二级选项,选择后显示在TextField里。 如何实现呢?建立一个和左边的列表key对应的数组,当选择这个key时,刷新左边UIPickerView部...
  • lejuo
  • lejuo
  • 2013年08月23日 10:08
  • 1077

TreeView 滚动条 子节点定位 页面回发刷新后,滚动条自动定位到被选择节点出,javascript库jQuery实现 兼容服务器端控件

jQuery实现 选择TreeView子节点,页面回送刷新后,滚动条自动回到TreeView顶部,而不是被选中节点处,对于数据量较大的系统而言是非常不方便操作的。 实现单击TreeView节点,页面...

ASP.NET服务器控件CheckBoxList修改

背景:asp.net自带的服务器控件CheckBoxList,在生成Html时,未显示name值,这样在表单提交后,Request.Form(它是根据name值来获取的)无法获取选中的值,故对此控件小...

CheckBoxList服务器控件

CheckBoxList服务器控件 CheckBoxList控件用来建立一个多选的复选框组。 CheckBoxList控件中的每个可选项由一个ListItems元素来定义! 可以操作一组项,而不...
  • itmaxin
  • itmaxin
  • 2012年04月25日 15:39
  • 353

.net FreamWork的服务器端控件源代码

  • 2009年03月12日 12:27
  • 1.29MB
  • 下载

dsoframer.ocx控件编辑后保存在服务器端的简单方法

在使用dsoframer.ocx控件的时候经常遇到需要将用户编辑的内容上传到服务器上。控件本身提供的方法是在JS中调用httpPost方法跳转到另一个资源中再进行处理。这种方法使用起来很不方便,下面介...

ajax 服务器端控件详解

  • 2012年01月08日 00:27
  • 1.39MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在服务器端得到CheckBoxList控件最后选择项的方法!
举报原因:
原因补充:

(最多只允许输入30个字)