0

基本上我正在从一个 sql 表中填充一个 gridview。但问题是特定列中的这些数据有时需要显示为下拉列表,有时需要显示为文本框。

例如,ColA 数据将始终采用标签格式。但 ColB 可以是下拉列表或文本框。

ColA   |   ColB
-----------------
label  |  ddlist    
label  |  textbox    
label  |  ddlist

如何动态设置每个 ColB 行的类型?我想也许可以使用 OnRowDatabound 来完成,但似乎找不到方法?这可能吗?

4

1 回答 1

0

试试这个:为 ColB 使用 TemplateField 并同时放置 TextBox 和 DropdownList

<asp:TemplateField HeaderText="ColB">
    <asp:TextBox runat="server" ID="txtVal" />
    <asp:DropdownList runat="server" ID="drpVal"></asp:DropdownList>
</asp:TemplateField>

在您的 gridview 的数据绑定中执行此操作

void myGridView_RowDataBound(Object sender, GridViewRowEventArgs e)
{
        TextBox txtVal = (TextBox)e.Row.FindControl("txtVal");
        DropDownList drpVal = (DropDownList)e.Row.FindControl("drpVal");

        if (txtVal != null && drpVal != null)
        {
            if (condition == true)
            {
                txtVal.Text = "Default value";
                drpVal.Visible = false;
            }
            else
            {
                drpVal.Items.Add("Item1");
                drpVal.Items.Add("Item2");
                drpVal.Items.Add("Item3");
                txtVal.Visible = false;
            }
        }
}
于 2012-09-25T21:07:31.430 回答