8

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

<asp:DropDownList ID="ddlChange_Requestor" runat="server" AppendDataBoundItems="True"  CssClass="ddlChange_Requestor">
    <asp:ListItem>Change Requestor</asp:ListItem>

在此处输入图像描述

我还有一个 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;
    }
}

这在 GridView 中的更改请求列/行具有值但不是“空白”/“空”/“空”时有效。我真的不知道如何解决它?

我希望能够做类似的事情:

ddlChange_Requestor.SelectedValue = isnullOrwhitespace(row.Cells[10].Text , "Change Requestor");

但是我只希望在后台使用它,因为我想在 GridView 中有空行,但在 RowCommand 上Select应该明白空意味着ListItem值。

这可能吗?

4

2 回答 2

6

难道不是简单地检查单元格 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;
}

假设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;
    }
}
于 2018-04-04T10:15:30.793 回答
-1
<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<script>
     (adsbygoogle = window.adsbygoogle || []).push({
          google_ad_client: "ca-pub-2343935067532705",
          enable_page_level_ads: true
     });
</script>
于 2018-09-24T13:45:40.193 回答