DataGrid中四种取值方式(实用)

本文介绍了在DataGrid中获取不同类型的列值的四种方法,并提供了详细的示例代码及解析。适用于初学者理解如何通过多种方式从DataGrid中读取数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们在DataGrid的使用中经常会遇到取得DataGrid的值的问题。
有4种方式可能遇到的情况:
(1)绑定列
<asp:BoundColumn DataField="vName"
HeaderText="姓名1"></asp:BoundColumn>
(2)模板列中直接放静态的字符串
<asp:TemplateColumn HeaderText="姓名2"> 
<ItemTemplate>  姓名 </ItemTemplate> 
</asp:TemplateColumn>
(3)模板列中直接放绑定的字符串
 <asp:TemplateColumn HeaderText="姓名3">
<ItemTemplate> 
<%#DataBinder.Eval(Container.DataItem,"vName")%>
</ItemTemplate> 
</asp:TemplateColumn>
(4)模板列中通过Label放绑定的字符串
<asp:TemplateColumn HeaderText="姓名4">
<ItemTemplate> 
<asp:Label ID="name" Runat="server"
Text='<%#DataBinder.Eval(Container.DataItem,"vName")%>'> 
</asp:Label>

</ItemTemplate> 
</asp:TemplateColumn>

view plaincopy to clipboardprint?

<ASP:DATAGRID id=DataGrid1 AllowPaging="True" AutoGenerateColumns="False" runat="server">    

 2                <COLUMNS>    

 3                    <ASP:BOUNDCOLUMN HeaderText="姓名0" DataField="vName"></ASP:BOUNDCOLUMN>    

 4                    <ASP:TEMPLATECOLUMN HeaderText="姓名1">    

 5                        <ITEMTEMPLATE>    

 6                            姓名    

 7                        </ITEMTEMPLATE>    

 8                    </ASP:TEMPLATECOLUMN>    

 9                    <ASP:TEMPLATECOLUMN HeaderText="姓名2">    

10                        <ITEMTEMPLATE>    

11                            <%#DataBinder.Eval(Container.DataItem,"vName")%>    

12                        </ITEMTEMPLATE>    

13                    </ASP:TEMPLATECOLUMN>    

14                    <ASP:TEMPLATECOLUMN HeaderText="姓名3">    

15                        <ITEMTEMPLATE>    

16                            <ASP:LABEL id=name Text='<%#DataBinder.Eval(Container.DataItem,"vName")%>' Runat="server">    

17                            </ASP:LABEL>    

18                        </ITEMTEMPLATE>    

19                    </ASP:TEMPLATECOLUMN>    

 

 

20                    <ASP:BUTTONCOLUMN Text="删除" CommandName="del" ButtonType="PushButton"></ASP:BUTTONCOLUMN>    

21                </COLUMNS>    

22            </ASP:DATAGRID>    

 

 

 

 

 

 

后台代码:c#   

if(e.CommandName=="del")    

2  {    

3  Response.Write("姓名1:"e.Item.Cells[0].Text);    

4  Response.Write("姓名2:"+e.Item.Cells[1].Text.Trim()+"<BR>");    

5  Response.Write("姓名3:"+((DataBoundLiteralControl)e.Item.Cells[2].Controls[0]).Text.Trim());    

6 Response.Write("姓名4:"+((Label)e.Item.Cells[3].FindControl("name")).Text);                    

7  }    

 

 

 

说明:   

(1)第一种用绑定列的方式可以直接通过Cells[i].Text取    

(2)第二种方式也直接可以取,但是讨厌的vs.net总是会在前台把列中的内容换行,所以这里还需要对输出的东西进行去除首尾的空格    

(3)第三种方式是网友问的最多的,不能直接通过Cells[i].Text取到值,可以通过上面给出的方法来取,同样需要去除首尾的空格    

(4)第四种方式也是最简单的方式,当然你可以直接写e.Item.FindControl("name")  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值