DataGrid模板列的CheckBox事件定义方法

  DataGrid的模板列中使用CheckBox是很常见的现象,而每个CheckBox怎么触发事件,又如何得到发生事件的当前行数据,是本文描述的中心。它并没有什么技术含量,但不了解的话,会让你在这里浪费一些时间。举个简单的例子:你需要在点击DataGrid上的CheckBox后,在将当前行数据复制到另一个表格中。

    ok,言归正传。

    假设当前有这样一个DataGird:

<asp:datagrid id="preCustList" Runat="server" width="100%" AutoGenerateColumns="False">

    <Columns>

    <asp:BoundColumn DataField="CustomerID" HeaderText="Customer ID"></asp:BoundColumn>

    <asp:BoundColumn DataField="NameCn" HeaderText="Customer Name"></asp:BoundColumn>

    <asp:BoundColumn DataField="CustCateGoryType" HeaderText="Customer Category"></asp:BoundColumn>

    <asp:BoundColumn DataField="PcAppDate" HeaderText="Create On" DataFormatString="{0:yyyy-MM-dd}"></asp:BoundColumn>

    <asp:TemplateColumn HeaderText="Is Tran">

        <ItemTemplate>

            <asp:CheckBox ID="aspTran" Runat="server" AutoPostBack="True" OnCheckedChanged="TranChecked"></asp:CheckBox>

        </ItemTemplate>

    </asp:TemplateColumn>

    </Columns>

</asp:datagrid>

  这里的做法是:在页面定义OnCheckedChange事件,让.net的托管机制自动注册事件与回调方法的关系。有不少帖子是在DataGrid的 ItemDataBind事件中,通过FindControl()找到CheckBox后,动态注册。我做过测试,没有效果。   接下来,你需要在后台页面定义一个protected或public的TranChecked方法,注意这里设定为private权限,是无法访问的: protected void TranChecked(object sender, System.EventArgs e)

{

        // sender为事件源,我们可以通过下面的方式获得DataGrid当前行

        CheckBox cb = (CheckBox)sender; DataGridItem item = cb.Parent.Parent;

        // 第一个Parent得到的是item的cell;第二个Parent得到Item 

        // 下面就可以操作item的其他cells了

        .......

}

----------------------------------------------------------------------------------  

实际上,使用CheckBox的客户端事件,更为简单:  

 <asp:datagrid id="preCustList" Runat="server" width="100%" AutoGenerateColumns="False">

     <Columns>

      <asp:BoundColumn DataField="CustomerID" HeaderText="Customer ID"></asp:BoundColumn>

      <asp:BoundColumn DataField="NameCn" HeaderText="Customer Name"></asp:BoundColumn>

      <asp:BoundColumn DataField="CustCateGoryType" HeaderText="Customer Category"></asp:BoundColumn>

      <asp:BoundColumn DataField="PcAppDate" HeaderText="Create On" DataFormatString="{0:yyyy-MM-dd}"></asp:BoundColumn>

      <asp:TemplateColumn HeaderText="Is Tran">

      <ItemTemplate>

            <input type="checkbox" name="Tran" id="Tran" onclick="Checked('<%# DataBinder.Eval(Container.DataItem,"CustomerID")%>', '<%# DataBinder.Eval(Container.DataItem,"NameCn")%>', '<%# DataBinder.Eval(Container.DataItem,"CustCateGoryType")%>', '<%# DataBinder.Eval(Container.DataItem,"PcAppDate")%>')" />

    </ItemTemplate>

    </asp:TemplateColumn>

    </Columns>

</asp:datagrid>

<table id="listtable">

    <tr>

        <td>Customer ID</td>

        <td>Customer Name</td>

        <td>Customer CateGory</td>

        <td>Create On</td>

        <td>Is Tran</td>

    </tr>

    <tr>

        td>&nbsp;</td>

        <td>&nbsp;</td>

        <td>&nbsp;</td>

        <td>&nbsp;</td>

        <td>&nbsp;</td>

    </tr>

</table>

客户端方法Checked的定义如下:

function Checked(customerID, customerName, customerCategory, createOn)

{  

      // 第一行赋值

      var temp = document.getElementById("listtable");

      var strRow = temp.rows[temp.rows.length - 1];

      strRow.cells[0].innerText = customerID;

      strRow.cells[1].innerText = customerName;

      strRow.cells[2].innerText = customerCategory;

      strRow.cells[3].innerText = createOn;

      strRow.cells[4].innerHTML = '<a onclick="javascript:deleteCurrentRow();" href="#">删除</a>';

   

      // 再新添一空行

      document.all('listtable').outerHTML = document.all('listtable').outerHTML.replace(/<//table>/i,

       '<tr><td> </td><td> </td><td> </td><td> </td><td> </td></tr>'   +   "</table>")

}    

deleteCurrentRow()的方法就不贴上来的。  

----------------------------------------------------------------------------------  

【总结】  

    客户端实现的响应速度显然快于在服务端实现的方法,而且不用页面跳转,没有烦人的刷新现象。但是客户端事件有一个致命的问题:由于下面Table的数据插入是在客户端进行的,只要页面刷新,数据就会丢失,录入:当你上面的DataGrid实现了翻页功能后,每翻一页,以前选定的数据就会丢失。  

    当然,你可能会说用隐藏域(<input type="hidden"/>)可以解决问题,但毕竟删除隐藏域的记录不方便。

 

时间: 2024-12-21 02:23:58

DataGrid模板列的CheckBox事件定义方法的相关文章

关于datagrid模板列中checkbox表头是否选中的问题!在线等!

问题描述 我现在在datagrid模板列中表头列里的checkbox中事件写的是:foreach(DataGridItemdginDataGrid1.Items){CheckBoxc1=(CheckBox)dg.Cells[6].FindControl("ch1");if(c1.Checked==false){c1.Checked=true;}else{c1.Checked=false;}}但是发现了一个问题,如果列表中有部分checkbox控件选择上了,有的没选择上,这个时候单击表头

求教:获得datagrid模板列里控件的值

问题描述 我用的2005我在datagrid模板列里绑定了一个textbox控件,在页面上另外有一个保存按钮,我想能实现在点击保存按钮的时候,获得textbox的值,但是我在响应点击事件的时候,通过findcontrol可以找到这个textbox,不过里面的值却始终为空.请大家帮忙啊!谢谢<asp:DataGridID="gdData"runat="server"CssClass="sdatagridex_a"CellPadding=&qu

RadioButtonList在Datagrid模板列中的应用

datagrid|模板 1.RadioButtonList插入DataGrid模板列的方法与其他控件插入的方法一致. 2.从数据库中读取RadioButtonList状态的方法 1) .aspx文件 <asp:RadioButtonList .... SelectedIndex='<%# Container.DataItem("strRBL") %>'> 2) .vb文件 objDataSet.Tables(0).Columns.Add("strRBL

JS判断Datalist模板列中checkbox是否有被选中!问题

问题描述 用JS判断Datalist模板列中checkbox是否有被选中的如果一个都没选中就弹出提示"一个都没选中"(为什么要用JS?因为JS不用回执服务器)大侠多贴代码出来!!本人很菜!!谢谢 解决方案 解决方案二:自己顶下解决方案三:UPUP解决方案四:怎么没人来啊~~解决方案五:DING解决方案六:帮顶几下!!解决方案七:顶顶解决方案八:顶起来在说~!解决方案九:大侠来帮忙啊!解决方案十:没有人会吗?上传一点,谢谢解决方案十一:functiongetSelectCount(){v

关于datagrid模板列中填加控件的疑问(非常简单)

问题描述 刚用.net2003在datagrid中模板列中加入了一个控件,为什么该控件没有'事件'选项.在2005里datagridview中模板列中加控件后,此控件就有'事件'.究竟是为什么啊?在2003里为什么就没有事件啊?05是不是把这个问题给解决了啊?还是怎么的?请高手赐教! 解决方案 解决方案二:直接在html中增加事件不就行了嗎?解决方案三:我是解决这个问题了就是不知道为什么没有事件!解决方案四:05有,那就用05吧,呵呵解决方案五:晕我就是想知道为什么03里的datagrid没有这

VB.net技巧之六------DataGrid模板列中的超级链接

datagrid|技巧|链接|模板 WebForm2.aspx 文件: <%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm2.aspx.vb" Inherits="house.WebForm2"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN&

DataGrid模板列中的超级链接

datagrid|链接|模板   WebForm2.aspx 文件: <%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm2.aspx.vb" Inherits="house.WebForm2"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN&q

用代码创建DataGrid的多链接及checkbox事件响应

datagrid|创建|链接|响应 本例用代码实现了创建DataGrid并响应了CheckBox事件,并实现了超链接列的多变量传送. 创建一个前台页面 CreateDataGrid.aspx: 在Form中添加一个PlcaeHolder,ID为"ph",Runat="Server" 后台页面 CreateDatagrid.aspx.cs     public class CreateDataGrid : System.Web.UI.Page    {       

wpf mvvm 模式的datagrid控件模板列的列头里的checkbox怎么在viewmodel里撤销勾选状态

问题描述 wpfmvvm模式的datagrid控件模板列的列头里的checkbox怎么在viewmodel里撤销勾选状态点击全选,点击下一页分以后全选框还是勾选状态,希望datagrid重新加载数据后模板的全选状态为未勾选, 解决方案 解决方案二:你需要编写勾选的点击事件,绑定只是用来显示而不是做动作处理,mvvm模式也需要后台事件处理的支持的.