'detailsUserTitle'有一个SelectedValue,它是无效的,因为它在项目列表中不存在。参数名称:value

时间:2014-09-08 07:05:43

标签: c# asp.net drop-down-menu

DropDownList不断返回此错误:(

这是我的aspx代码

<asp:DetailsView ID="DetailsView1" runat="server" Height="50px" Width="125px" AutoGenerateRows="False" DataKeyNames="username" DataSourceID="SqlDataSource1" BackColor="#DEBA84" BorderColor="#DEBA84" BorderStyle="None" BorderWidth="1px" CellPadding="3" CellSpacing="2">
    <EditRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="White" />
    <Fields>
        <asp:TemplateField HeaderText="username" SortExpression="username">
            <ItemTemplate>
                <asp:Label ID="Label9" runat="server" Text='<%# Bind("username") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Title" SortExpression="title">
            <EditItemTemplate>
                <asp:DropDownList ID="detailsUserTitle" runat="server" SelectedValue='<%# Bind("title") %>' DataSourceID="SqlDataSource1">
                    <asp:ListItem Value="-1">Select Title</asp:ListItem>
                    <asp:ListItem Value="Mr">Mr</asp:ListItem>
                    <asp:ListItem Value="Mrs">Mrs</asp:ListItem>
                    <asp:ListItem Value="Miss">Miss</asp:ListItem>
                    <asp:ListItem Value="Ms">Ms</asp:ListItem>
                </asp:DropDownList>
                <asp:RequiredFieldValidator ID="RequiredFieldValidatorTitle" 
                    ControlToValidate="detailsUserTitle" runat="server" ErrorMessage="Title is a required field" 
                    Text="*" ForeColor="Red" InitialValue="-1"></asp:RequiredFieldValidator>
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("title") %>'></asp:TextBox>
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label1" runat="server" Text='<%# Bind("title") %>'></asp:Label>
            </ItemTemplate>

我一直在网上寻求建议,但没有一个确凿的帮助我。请帮忙。我没有添加任何与此问题相关的代码。

谢谢

1 个答案:

答案 0 :(得分:0)

您的问题在于DDL属性SelectedValue='<%# Bind("title") %>'

您的SQL数据源“ SqlDataSource1 ”可能无法返回Mr,Mrs,Miss或MS中的任何值。

如果标题字段具有不同的值,则会出现此错误

<强>更新

您可以在绑定之前验证您的标题字符串,如下所示。但是,我不建议这样做。如果您可以在从数据源检索之前验证值,我更喜欢。理想的解决方案是在查找其中的值之前将DropDownList与相同的值集绑定。那么你就不会错过任何东西。

这是快速修复。 : - )

SelectedValue='<%# (!string.IsNullOrEmpty(Bind("title")) || "Mr, Mrs, Miss, MS".IndexOf(Bind("title")) > -1) ? Bind("title") : "-1" %>'

更新2 你去了:-D

SelectedValue='<%# (!string.IsNullOrEmpty((string)Eval("title")) || "Mr, Mrs, Miss, MS".IndexOf((string)Eval("title")) > -1) ? (string)Eval("title") : "-1" %>'

如果它解决了您的问题,请接受答案。一切顺利!