0

我有一个下拉列表,其中填充了来自 SQL 服务器的数据。

我在Page_Init()事件中动态填充下拉列表。根据值,选择一个 ListItem。

现在的问题是,当我在下拉列表中选择另一个项目时,回发后选择被重置为下拉列表中的第一个项目。

这是我的代码的基本版本,它不起作用:

        ArrayList AD_Group_Members = ActiveDirectory.GetMemberOfGroup("AD-Group");
        ArrayList ListMachines = SQLQuery.Read("Database", "SELECT idVM, RandomString, Computername, Owner, FROM VM ORDER BY Computername");

        for (int i = 0; i < ListMachines.Count; i++)
        {
            String RandomString = ((Hashtable)ListMachines[i])["RandomString"].ToString();
            String Owner = ((Hashtable)ListMachines[i])["Owner"].ToString();
            DropDownList DropDownList_Owner = new DropDownList();
            DropDownList_Owner.ID = "DropDownList_Owner_" + RandomString;
            DropDownList_Owner.Width = Unit.Percentage(95);
            DropDownList_Owner.AutoPostBack = true;
            DropDownList_Owner.EnableViewState = true;
            DropDownList_Owner.SelectedIndexChanged += DropDownList_Owner_SelectedIndexChanged;
            Div_Test.Controls.Add(DropDownList_Owner);
            for (int y = 0; y < AD_Group_Members.Count; y++)
            {
                ListItem ListItem = new ListItem();
                ListItem.Value = Owner;
                ListItem.Text = ((Hashtable)AD_Group_Members[y])["GivenName"].ToString() + " " + ((Hashtable)AD_Group_Members[y])["Surname"].ToString();
                if (((Hashtable)AD_Group_Members[y])["Username"].ToString().Equals(Owner))
                {
                    ListItem.Selected = true;
                }
                DropDownList_Owner.Items.Add(ListItem);
            }
        }

我的代码中的问题在哪里,它不起作用,而是示例。预先感谢

4

3 回答 3

7

在这种情况下,您必须在页面加载时填充您的下拉列表。因为在每次回帖时,您的 ddl 都会再次填充并丢失其选定的索引。

if (!IsPostBack)
{
    //PopulateYourDDL here
}
于 2013-07-19T09:33:34.473 回答
0

我认为您应该为下拉菜单设置独特的值。此外,由于您在数据值字段中有重复值,因此问题正在发生。它正在寻找第一个匹配项并选择它。您可以尝试制造您可以唯一识别的值。如下所示:

COLUMN_NAME  DATA_TYPE
a            a_decimal
b            b_decimal
c            c_decimal
d            d_int
e            e_int
f            f_varchar
g            g_varchar
h            h_varchar
i            i_varchar
j            j_varchar

看看这个有用的来源!我希望它有帮助!!!仔细查看已接受答案部分中的那些评论!!!

还要避免在处理动态生成的 Web 控件时使用 SelectedIndex_Changed() 函数。在 Page_Init() 或 Page_PreInit() 下绑定 DropdownList。如果您想在 DropDownlist Selection 上执行某些功能,请查看此!确定被触发的 WebControl ID,然后在 Page_PreInit() 或 Page_Init() 中执行独特的功能。

于 2014-06-12T05:42:16.507 回答
0

您填写了下拉列表,Page_Init()在每个回发中都会调用它并重新填写您的下拉列表,因此会丢失 selectedindex。因此您必须在!ispostback块内填写您的下拉列表

if (!IsPostBack)
{
   //fill your dropdown here
}
于 2013-07-19T09:48:40.873 回答