使用DropDownList的Gridview RowCommand事件不起作用

Nil*_*ils 8 c# asp.net gridview rowcommand dropdown

我创建了一些DropDownLists,它们填充了数据库中的数据.下拉列表的第一ListItem:

<asp:DropDownList ID="ddlChange_Requestor" runat="server" AppendDataBoundItems="True"  CssClass="ddlChange_Requestor">
    <asp:ListItem>Change Requestor</asp:ListItem>
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

我还有一个GridView,它在Select按钮上有一个RowCommand事件.

在此输入图像描述

当我按下SelectDropDownLists时,将获得所尊重的列/行所具有的任何值:

protected void gwActivity_RowCommand(object sender, GridViewCommandEventArgs e)
{
    {
        GridViewRow row = ((e.CommandSource as Control).NamingContainer as GridViewRow);
        txtActivity.Text = row.Cells[2].Text;
        ddlChange_Requestor.SelectedValue = row.Cells[10].Text;
    }
}
Run Code Online (Sandbox Code Playgroud)

当GridView中的Change Request列/行具有值但不是"white-space"/"Empty"/"Null"时,这种方法有效.我真的不知道如何解决它?

我希望能够做到这样的事情:

ddlChange_Requestor.SelectedValue = isnullOrwhitespace(row.Cells[10].Text , "Change Requestor");
Run Code Online (Sandbox Code Playgroud)

但是我只想在后台使用它,因为我想在GridView中有空行但在RowCommand上Select应该理解空ListItem值意味着值.

这可能吗?

VDW*_*WWD 6

是不是只是检查Cell 10中的值是否为空?

if (!string.IsNullOrEmpty(row.Cells[10].Text) && row.Cells[10].Text != "&nbsp;")
{
    ddlChange_Requestor.SelectedValue = row.Cells[10].Text;
}
else
{
    ddlChange_Requestor.SelectedIndex = 0;
}
Run Code Online (Sandbox Code Playgroud)

假设ddlChange_Requestor是GridView之外的DropDown.

如果您不确定DLL中是否存在单元格值,则可以先进行检查.

if (!string.IsNullOrEmpty(row.Cells[10].Text))
{
    string value = row.Cells[10].Text;

    if (ddlChange_Requestor.Items.Cast<ListItem>().Any(x => x.Value == value))
    {
        ddlChange_Requestor.SelectedValue = value;
    }
    else
    {
        ddlChange_Requestor.SelectedIndex = 0;
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 没问题.但请记住,使用像这样的单元格值会产生奇怪的结果.它不是字符串值的问题,但是当涉及日期和小数时,最好使用源数据,因为这些类型在单元格文本中转换为字符串. (2认同)