如何取到GridView的DataField的名称?
在GridView的外部设置一个按钮,点击该按钮时如何能取到该GridView列所绑定的各个DataFiled的名称?
BoundField和TemplateField,尤其是如何取到TemplateField中的某控件所绑定的DataFiled的名称。
- HTML code
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default8_CSDN.aspx.cs" Inherits="_Default8_CSDN" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" ><head runat="server"> <title>Get GridView's HeaderText and the DataField</title></head><body> <form id="form1" runat="server"> <div> <asp:Button ID="Button1" runat="server" Text="Get GridView's DataField" OnClick="Button1_Click" /> <p /> <asp:Label ID="Label1" runat="server" Text=""></asp:Label> <p /> <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"> <Columns> <asp:BoundField DataField="EmployeeID" HeaderText="ID" ReadOnly="True" /> <asp:TemplateField HeaderText="Name"> <EditItemTemplate> <asp:TextBox ID="gvtxtName" runat="server" Text='<%# Eval("EmployeeName") %>'></asp:TextBox> </EditItemTemplate> <ItemTemplate> <asp:Label ID="gvlbllName" runat="server" Text='<%# Bind("EmployeeName") %>'></asp:Label> </ItemTemplate> </asp:TemplateField> <asp:BoundField DataField="EmployeeAge" HeaderText="Age" ReadOnly="True" /> </Columns> </asp:GridView> </div> </form></body></html>cs:
- C# code
using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls; public partial class _Default8_CSDN : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { GridView1.DataSource = GetTable(); GridView1.DataBind(); } } /// <summary> Button1 : 列出GridView的HeaderText和所绑定的DataField /// </summary> protected void Button1_Click(object sender, EventArgs e) { System.Text.StringBuilder sb = new System.Text.StringBuilder(); for (int i = 0; i < GridView1.Columns.Count; i++) { sb.Append("第" + (i+1).ToString() + "列 ========="); sb.Append("HeaderText: "); sb.Append(GridView1.Columns[i].HeaderText); sb.Append("========="); sb.Append("DataField: "); sb.Append("???"); // 请问这里怎么写,望高手指教。 sb.Append("<br/>"); } Label1.Text = sb.ToString(); } /// <summary> 创—ataTable /// </summary> /// <returns></returns> private DataTable GetTable() { DataTable dt = new DataTable(); dt.Columns.Add("EmployeeID"); dt.Columns.Add("EmployeeName"); dt.Columns.Add("EmployeeAge"); for (int i = 0; i < 5; i++) { dt.Rows.Add(new string[] { "ID" + i.ToString(), "Name" + i.ToString(), (i+20).ToString() }); } return dt; } }
[解决办法]
((BoundField)this.GridView1.Columns[0]).DataField
[解决办法]
if(GridView1.Columns[i] is BoundField)
{
}
else if(GridView1.Columns[i] is TemplateField)
{
}
[解决办法]
我重新整理了一下
- C# code
protected void Button1_Click(object sender, EventArgs e) { System.Text.StringBuilder sb = new System.Text.StringBuilder(); DataTable dt = this.GetTable(); for (int i = 0; i < GridView1.Columns.Count; i++) { sb.Append("第" + (i + 1).ToString() + "列 ========="); sb.Append("HeaderText: "); sb.Append(GridView1.Columns[i].HeaderText); sb.Append("========="); sb.Append("DataField: "); if (this.GridView1.Columns[i] is BoundField) { sb.Append(((BoundField)this.GridView1.Columns[i]).DataField); } else if(this.GridView1.Columns[i] is TemplateField) { sb.Append(dt.Columns[i].ColumnName); } sb.Append("<br/>"); } Label1.Text = sb.ToString(); }
[解决办法]
UP,
sb.Append(dt.Columns[i].ColumnName);?????
那不用if.else了,
if (this.GridView1.Columns[i] is BoundField)
{
sb.Append(((BoundField)this.GridView1.Columns[i]).DataField);
}
else if(this.GridView1.Columns[i] is TemplateField)
{
sb.Append(dt.Columns[i].ColumnName);
}
直接
sb.Append(dt.Columns[i].ColumnName);
[解决办法]
<ItemTemplate>
<asp:Label ID="gvlbllName" runat="server" Text='<%# Bind("k_employName") %>'></asp:Label>
</ItemTemplate>
按我理解的,这个自定义绑定语法 Bind 或者 Eval 函数中的 属性名,如这里的 k_employName 应该无法通过代码模型取得的!
因为 Bind 或者 Eval 实际上是经过 asp.net 解析器解析成 C#/VB.net ... 代码的,与 BoundField.DataField 是不同的
[解决办法]
顶13楼, <%# Bind("k_employName") %>实际就是你手写调用了后台方法,参数"k_employName"也是你手写定义的,既然写死了,就写死到底吧。
如果一定要动态去取,两个方案,1.事先将数据源的列顺序排好,不要打乱,直接调dt.Columns[i].ColumnName;
2.模板列里面的控件名与要绑定的列名一致,或者是放一个隐藏Label,Label.Text="要绑定的列名"。
这样在取的时候就去问控件要属性。
[解决办法]
可能就如13楼的哥们所说的,无法获取到模版列的DataField吧。
=========
此时根本就没有所谓的 DataField , 你有看到嘛? Bind 和 Eval 实际上是函数。