在Gridview列中显示图像,需要动态创建列

时间:2011-09-08 22:31:10

标签: asp.net gridview

我需要在GridView控件中显示图像。列创建需要是动态的。换句话说,整个列的创建需要在代码中完成。

很多帖子都引用http://msdn.microsoft.com/en-us/library/aa479350.aspx。问题是我需要动态创建列,因为我事先不知道图像列是否会显示。此外,该文章可能很旧,因为它仍然引用asp.net 2.0版。我在vs2010中开发它,我相信使用asp.net版本3.5(或更高版本)

1 个答案:

答案 0 :(得分:0)

如果您想要一个真正的动态网格,那么您可以在代码中构建网格。这有点棘手,但并非不可能。这是一个自包含的示例,您可以查看。

<%@ Page Language="C#" AutoEventWireup="true"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">

    class MyItemTemplate : System.Web.UI.ITemplate
    {

        public void InstantiateIn(System.Web.UI.Control container)
        {
            Label label = new Label();
            label.ID = "MyLabel";
            container.Controls.Add(label);
        }
    }

    protected void Page_Load(object sender, EventArgs e)
    {
        GridView gv;
        if (!this.IsPostBack)
        {
            gv = new GridView();
            gv.AutoGenerateColumns = false;
            gv.ID = "MyGrid";
            var column = new TemplateField();
            column.HeaderText = "My Item";
            column.ItemTemplate = new MyItemTemplate();
            gv.Columns.Add(column);
            MyDiv.Controls.Add(gv);
            gv.RowDataBound += new GridViewRowEventHandler(gv_RowDataBound);
        }

        var dataSource = new string[] { "a", "b", "c" };
        gv = this.Page.FindControl("MyGrid") as GridView;

        gv.DataSource = dataSource;
        gv.DataBind();
    }

    void gv_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        var label = e.Row.FindControl("MyLabel") as Label;
        if (label != null)
            label.Text = ((string)e.Row.DataItem).ToUpper();
    }
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div id="MyDiv" runat="server">

    </div>
    </form>
</body>
</html>