使用itemDatabound在转发器内的dropdownlist findbyvalue

时间:2012-09-14 22:01:13

标签: vb.net drop-down-menu repeater itemdatabound

我正在尝试设置一个转发器,该转发器具有下拉列表,这些转发器的数据是根据使用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

1 个答案:

答案 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()。