Gridview Добавляет столбцы динамически, используя код позади - PullRequest
0 голосов
/ 23 января 2012

Я пытаюсь динамически создавать столбцы с помощью кода C #, мне нужно создать столбец с текстовыми полями, как я могу продолжать это делать? Вот мой код:

protected void loadTable()
{
    gv_productDesc.Columns.Clear();
    SqlConnection con = new SqlConnection();
    con.ConnectionString = ConfigurationManager.ConnectionStrings["UserCS"].ConnectionString;

    string sql = "SELECT * FROM ItemTable WHERE categoryId=@pcategoryId";
    SqlCommand cmd = new SqlCommand(sql, con);

    cmd.Parameters.AddWithValue("@pcategoryId", ddl_category.SelectedValue);

    SqlDataReader dr;
    DataTable dt = new DataTable();

    try
    {
        con.Open();
        dr = cmd.ExecuteReader();
        dt.Load(dr);

        /*BoundField itemname = new BoundField();
        itemname.HeaderText = "Item Name";
        itemname.HeaderStyle.CssClass = "gridPadding";
        itemname.DataField = "itemName";
        itemname.ItemStyle.CssClass = "gridPadding";
        itemname.ItemStyle.Font.Bold = true;
        itemname.ItemStyle.Width = 225;
        gv_productDesc.Columns.Add(itemname);*/

        ButtonField btnfield = new ButtonField();
        btnfield.HeaderText = "Item Name";
        btnfield.HeaderStyle.CssClass = "gridPadding";
        btnfield.ButtonType = ButtonType.Link;
        btnfield.DataTextField = "itemName";
        btnfield.CommandName = "lala";
        btnfield.ItemStyle.CssClass = "linkcss";
        btnfield.ItemStyle.Width = 225;
        gv_productDesc.Columns.Add(btnfield);

        BoundField itemprice = new BoundField();
        itemprice.HeaderText = "Item Price ($)";
        itemprice.HeaderStyle.CssClass = "gridPadding";
        itemprice.DataField = "unitPrice";
        itemprice.ItemStyle.CssClass = "gridPadding";
        itemprice.ItemStyle.Font.Bold = true;
        itemprice.ItemStyle.Width = 100;
        gv_productDesc.Columns.Add(itemprice);

        BoundField itemdescHidden = new BoundField();
        itemdescHidden.HeaderText = "Item Description";
        itemdescHidden.DataField = "description";
        itemdescHidden.HtmlEncode = false;
        itemdescHidden.ItemStyle.Width = 0;
        gv_productDesc.Columns.Add(itemdescHidden);

        BoundField itemdesc = new BoundField();
        itemdesc.HeaderText = "Item Description";
        itemdesc.HeaderStyle.CssClass = "gridPadding";
        itemdesc.ItemStyle.CssClass = "gridPadding";
        itemdescHidden.DataField = "description";
        itemdesc.HtmlEncode = false;
        itemdesc.ItemStyle.HorizontalAlign = HorizontalAlign.Left;
        itemdesc.ItemStyle.Width = 320;
        gv_productDesc.Columns.Add(itemdesc);

        ImageField itemimage = new ImageField();
        itemimage.HeaderText = "Item Image";
        itemimage.HeaderStyle.CssClass = "gridPadding";
        itemimage.DataImageUrlField = "image";
        itemimage.ItemStyle.CssClass = "gridPadding";
        itemimage.ItemStyle.Width = 225;
        itemimage.ControlStyle.Width = 225;
        gv_productDesc.Columns.Add(itemimage);



        gv_productDesc.DataSource = dt;
        gv_productDesc.DataBind();
        gv_productDesc.Columns[2].Visible = false;
    }
    catch (Exception ex)
    {
        lb_msg2.Text = "Error Encountered : " + ex.Message;
    }
    finally
    {
        con.Close();
        con.Dispose();
        cmd.Dispose();
    }
}

Я попытался добавить столбец в GridView на главной странице (example.aspx), но когда я связал значения с GridView, этот столбец исчез.

1 Ответ

0 голосов
/ 10 февраля 2016

Привязка данных к GridView всегда будет перерисовывать GridView на основе столбцов, возвращаемых источником данных. В вашем случае вам нужно либо добавить столбцы как часть вашего источника данных, либо установить AutoGenerateColumns="False"

UPDATE

Поместите ваши динамические элементы управления ПОСЛЕ кода, связывающего данные с табличным представлением, согласно моему первоначальному комментарию выше.

...