0

我有一个GridView, 的标题字段是我程序GridView中 aListBox的项目。因此,每次运行时生成的列数都是动态的。基于此,如果我单击我的内部关联的编辑按钮GridView,如何TextBox为该行的每个单元格生成一个?

我写的.cs代码是:

protected void DONE4_Click(object sender, EventArgs e)
{
    Panel7.Visible = true;

    SqlDataAdapter mydat = new SqlDataAdapter("SELECT DISTINCT Profile_Instance FROM Profile_Master", con);
    DataSet dst = new DataSet();
    mydat.Fill(dst, "Table");
    ListBox3.Items.Clear();
    ListBox3.DataSource = dst.Tables[0];
    ListBox3.DataTextField = dst.Tables[0].Columns["Profile_Instance"].ColumnName;
    ListBox3.DataBind();

    int count = ListBox3.Items.Count;

    DataTable dt = new DataTable();
    DataRow rw = default(DataRow);
    for (int i = 0; i < ListBox1.Items.Count; i++)
    {
        dt.Columns.Add(ListBox1.Items[i].ToString(),
                                       System.Type.GetType("System.String"));
    }

    for (int j = 0; j < count; j++)
    {
        rw = dt.NewRow();
        for (int i = 0; i < ListBox1.Items.Count; i++)
        {
            rw[ListBox1.Items[i].ToString()] = " ";
        }
        dt.Rows.Add(rw);
    }

    GridView2.DataSource = dt;
    GridView2.DataBind();

    foreach (GridViewRow grdRow in GridView2.Rows)
    {
        DropDownList bind_dropdownlist = new DropDownList();                                                    // defining the property of the DropDownList as bind_dropdownlist
        bind_dropdownlist = (DropDownList)(GridView2.Rows[grdRow.RowIndex].Cells[0].FindControl("Pro_List"));   // finding the  DropDownList from the gridiew for binding
        SqlDataAdapter mydata = new SqlDataAdapter("SELECT DISTINCT Profile_Instance FROM Profile_Master", con);
        DataSet dset = new DataSet();                                                                           // binding the DropDownList with the dataset ds
        mydata.Fill(dset, "Table");
        bind_dropdownlist.DataSource = dset;
        bind_dropdownlist.DataTextField = "Profile_Instance";                                                   // set the DropDownList's DataTextField as designation which display the designation in the dropdownlist after fetching the data from database
        bind_dropdownlist.DataBind();
        bind_dropdownlist.Items.Insert(0, new ListItem("---Choose Profile---", "-1"));
    }
}

的设计代码GridView是:

<asp:Panel ID="Panel7" runat="server">
    <asp:GridView ID="GridView2" runat="server" CellPadding="4"
        style="text-align: center; font-size: small" BackColor="White" 
        BorderColor="#CC9966" BorderStyle="None" BorderWidth="1px">

        <Columns>                
        <asp:TemplateField HeaderText="">
            <ItemTemplate>
                <asp:DropDownList ID="Pro_List" runat="server">
                    <asp:ListItem>--Select--</asp:ListItem>                          
                </asp:DropDownList>
            </ItemTemplate>
        </asp:TemplateField>

        <asp:CommandField ShowEditButton="True" />

        </Columns>
    </asp:GridView>
</asp:Panel>

有人可以帮我吗?我希望这个问题很清楚。

4

1 回答 1

1

如果您不是 BindingGridView并且仍想访问其中的控件,则可以使用该GridViewRow属性。

protected void grd_RowEditing(object sender, GridViewEditEventArgs e) 
{
     GridViewRow selectRow = grd.Rows[e.NewEditIndex];
     TextBox txtKj=(TextBox)selectRow.Cells[3].FindControl("txtKjId"); 
}
于 2012-08-25T07:03:06.090 回答