我正在尝试设置一个转发器,该转发器具有下拉列表,这些转发器的数据是根据使用linq从db填充的数组绑定的。
我遇到的问题是每个下拉列表在渲染时都具有相同的选定值,这也恰好是数组中的最后一个值。我需要每个选定的值与其标签相对应,该标签存储在先前提交的表格中。
func.ConfigurePastClientSetting(label.Text,krmid)返回一个值,该值等于ddl中已存储在过去表单提交的数据库中的值之一。
Private Sub rptDropDownInfo_ItemDataBound(sender As Object,
e As System.Web.UI.WebControls.RepeaterItemEventArgs) _
Handles rptDropDownInfo.ItemDataBound
Dim selected As New List(Of String)
If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem Then
Dim ddl As DropDownList = e.Item.FindControl("ddlEloquaValues")
Dim column As EbmsColumnLabel = DirectCast(e.Item.DataItem, EbmsColumnLabel)
ddl.Items.AddRange(ddlELQ.Items.OfType(Of ListItem)().ToArray())
ddl.ClearSelection()
ddl.Items.FindByValue(func.ConfigurePastClientSetting(column.displayname, krmid)).Selected = True
selected.Add(ddl.SelectedItem.Value)
End If
End Sub
如果我删除了ddl.ClearSelection,我会得到一个“下拉列表错误中不能有多个selectedvalue。这是标记:
<asp:Repeater ID="rptDropDownInfo" runat="server">
<HeaderTemplate><table><tr><td style="width:60px;padding-left:20px;">KRM</td><td></td><td>Eloqua</td></tr></table></HeaderTemplate>
<ItemTemplate>
<tr>
<asp:Label ID="lblColumnNames" runat="server" Text='<%# DataBinder.Eval(Container.DataItem, "DisplayName") %>'></asp:Label><td>map to</td>
<asp:DropDownList ID="ddlEloquaValues" runat="server">
</asp:DropDownList>
<td>
<asp:Label ID="lblWarningLabels" runat="server" Text=""></asp:Label></td></tr>
</ItemTemplate>
</asp:Repeater>
我尝试检查第一个(0)ddl.SelectedValue并获取数组中的最后一项:
Private Sub Page_PreRender(sender As Object, e As System.EventArgs) Handles Me.PreRender
If IsPostBack Then
Dim ddl As DropDownList = rptDropDownInfo.Items(0).FindControl("ddlEloquaValues")
Dim check = ddl.SelectedItem.Value
End If
End Sub
答案 0 :(得分:0)
似乎所有DDL都共享相同的ListItems实例。
因此,在项目上设置Selected = true会为共享它的所有DDL选择它。 这也是您在删除ClearSelection时遇到问题的原因
您应该创建新的ListItem,方法是让您的Linq查询通过Select实例化新的ListItem,而不是返回现有的ListItems)
希望这会有所帮助。
ddl.Items.AddRange(ddlELQ.Items.OfType(Of ListItem)().ToArray())
ddl.Items.FindByValue(func.ConfigurePastClientSetting(column.displayname, krmid)).Selected = True
selected.Add(ddl.SelectedItem.Value)
应该是(抱歉,C#语法):
ddl.Items.AddRange(ddlELQ.OfType<ListItem>().Select(li=>new ListItem(){Text = li.Text,Value = li.Value}).ToArray())
ddl.SelectedIndex = ddl.Items.IndexOf(ddl.Items.FindByValue(func.ConfigurePastClientSetting(column.displayname, krmid)));
如果要防止多重绑定,则应删除ClearSelection(),将其替换为ddl.Items.Clear()。