读书人

怎么取到GridView的DataField的名称

发布时间: 2012-04-30 22:33:26 作者: rapoo

如何取到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 实际上是函数。

读书人网 >asp.net

热点推荐