Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/305.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# “Sport”的SelectedValue无效,因为它不在项目列表中。参数名称:value_C#_Asp.net - Fatal编程技术网

C# “Sport”的SelectedValue无效,因为它不在项目列表中。参数名称:value

C# “Sport”的SelectedValue无效,因为它不在项目列表中。参数名称:value,c#,asp.net,C#,Asp.net,我对一般的编码还不熟悉,有一个任务,我需要使用ASP.net&C使用Visual studio创建一个时事通讯网站。很抱歉,如果我有些行话弄错了,我是新手 我有上面的错误,不能完全解决问题 下面是编辑新闻页面的代码。我有两个db的内部连接,你可以从select命令中看到。我想有一个下拉列表,让作者可以选择一项运动,因为目前在数据库中它是作为数字列出的,这是没有用的,如果他们不知道数字代表什么。我能够得到一个下拉列表,但是当我添加SelectedValue时,当作者选择一项运动时,它会更新数据库,

我对一般的编码还不熟悉,有一个任务,我需要使用ASP.net&C使用Visual studio创建一个时事通讯网站。很抱歉,如果我有些行话弄错了,我是新手

我有上面的错误,不能完全解决问题

下面是编辑新闻页面的代码。我有两个db的内部连接,你可以从select命令中看到。我想有一个下拉列表,让作者可以选择一项运动,因为目前在数据库中它是作为数字列出的,这是没有用的,如果他们不知道数字代表什么。我能够得到一个下拉列表,但是当我添加SelectedValue时,当作者选择一项运动时,它会更新数据库,不过,这是我得到错误的时候。我在一个插入页中有相同的代码字符串,它可以工作,因此非常感谢您的帮助:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="editnews.aspx.cs" Inherits="admin_editnews" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
            <link href="../css/bootstrap.css" rel='stylesheet' type='text/css' />
        <link href="../css/style.css" rel='stylesheet' type='text/css' />
</head>
<body>
    <form id="form1" runat="server">
    <div>

        <asp:SqlDataSource ID="newseditrows" runat="server" 
            ConnectionString="<%$ ConnectionStrings:newsconnection %>" 
            SelectCommand="SELECT News.headline, News.Image, News.paragraph, Sports.sport, News.Sport, News.date, News.lead, News.authorID, Sports.id
                            FROM News 
                            INNER JOIN Sports ON News.Sport = Sports.id
                            ORDER BY date DESC"
            UpdateCommand="UPDATE [News] SET [headline]=@headline, [Image]=@Image, [paragraph]=@paragraph, [Sport]=@sport, [date]=@date, [lead]=@lead, [authorid]=@authorid WHERE [id]=@id">

            <UpdateParameters>
                <asp:Parameter Name="headline" Type="String" />
                <asp:Parameter Name="Image" Type="String" />
                <asp:Parameter Name="paragraph" Type="String" />
                <asp:Parameter Name="Sport" Type="Int32" />
                <asp:Parameter Name="date" Type="String" />
                <asp:Parameter Name="lead" Type="String" />
                <asp:Parameter Name="authorid" Type="Int32" />
                <asp:Parameter Name="ID" Type="Int32" />
            </UpdateParameters>
        </asp:SqlDataSource>

        <asp:SqlDataSource ID="sportlist" runat="server" 
            ConnectionString='<%$ ConnectionStrings:newsconnection %>' 
            SelectCommand="SELECT [id], [sport] FROM [Sports]">

        </asp:SqlDataSource>

        <asp:ListView ID="displayedit" runat="server"
            DataSourceID="newseditrows"
            DataKeyNames="id">

            <AlternatingItemTemplate>
                <span style="">id:
                    <asp:Label Text='<%# Eval("id") %>' runat="server" ID="idLabel" /><br />
                    headline:
                    <asp:Label Text='<%# Eval("headline") %>' runat="server" ID="headlineLabel" /><br />
                    Image:
                    <asp:Label Text='<%# Eval("Image") %>' runat="server" ID="ImageLabel" /><br />
                    paragraph:
                    <asp:Label Text='<%# Eval("paragraph") %>' runat="server" ID="paragraphLabel" /><br />
                    Sport:
                    <asp:Label Text='<%# Eval("sport") %>' runat="server" ID="SportLabel" /><br />
                    date:
                    <asp:Label Text='<%# Eval("date") %>' runat="server" ID="dateLabel" /><br />
                    lead:
                    <asp:Label Text='<%# Eval("lead") %>' runat="server" ID="leadLabel" /><br />
                    authorID:
                    <asp:Label Text='<%# Eval("authorID") %>' runat="server" ID="authorIDLabel" /><br />
                    <asp:Button ID="EditButton" runat="server" CommandName="Edit" Text="Edit" />
                    <br />
                <br />
                </span>
            </AlternatingItemTemplate>
            <EditItemTemplate>
                <span style=""><%--id:
                    <asp:Label Text='<%# Eval("id") %>' runat="server" ID="idLabel1" /><br />--%>
                    Headline:
                    <asp:TextBox Text='<%# Bind("headline") %>' runat="server" ID="headlineTextBox" /><br />
                    Image:
                    <asp:TextBox Text='<%# Bind("Image") %>' runat="server" ID="ImageTextBox" /><br />
                    Paragraph:<br />
                    <asp:TextBox Text='<%# Bind("paragraph") %>' runat="server" ID="paragraphTextBox" 
                                 TextMode="MultiLine" Columns="50" Rows="8"/><br />
                    <br />Sport:
                    <%--<asp:TextBox ID="SportTextBox" runat="server" Text='<%# Bind("Sport") %>' />--%>
                    <asp:DropDownList ID="Sport" runat="server" 
                                        DataSourceID="sportlist" 
                                        DataTextField="sport" 
                                        DataValueField="id"
                                        SelectedValue='<%# Bind("Sport") %>' >

                    </asp:DropDownList>
                    <br />
                    <%--date:
                    <asp:TextBox Text='<%# Bind("date") %>' runat="server" ID="dateTextBox" /><br />--%>
                    Lead:
                    <asp:TextBox Text='<%# Bind("lead") %>' runat="server" ID="leadTextBox" /><br />
                    <%--authorID:
                    <asp:TextBox Text='<%# Bind("authorID") %>' runat="server" ID="authorIDTextBox" /><br />--%>
                    <asp:Button runat="server" CommandName="Update" Text="Update" ID="UpdateButton" /><asp:Button runat="server" CommandName="Cancel" Text="Cancel" ID="CancelButton" /><br />
                    <br />
                </span>
            </EditItemTemplate>
            <EmptyDataTemplate>
                <span>No data was returned.</span>
            </EmptyDataTemplate>
            <InsertItemTemplate>
                <span style="">headline:
                    <asp:TextBox Text='<%# Bind("headline") %>' runat="server" ID="headlineTextBox" /><br />
                    Image:
                    <asp:TextBox Text='<%# Bind("Image") %>' runat="server" ID="ImageTextBox" /><br />
                    paragraph:
                    <asp:TextBox Text='<%# Bind("paragraph") %>' runat="server" ID="paragraphTextBox" /><br />
                    Sport:
                    <asp:TextBox Text='<%# Bind("sport") %>' runat="server" ID="SportTextBox" /><br />
                    date:
                    <asp:TextBox Text='<%# Bind("date") %>' runat="server" ID="dateTextBox" /><br />
                    lead:
                    <asp:TextBox Text='<%# Bind("lead") %>' runat="server" ID="leadTextBox" /><br />
                    authorID:
                    <asp:TextBox Text='<%# Bind("authorID") %>' runat="server" ID="authorIDTextBox" /><br />
                    <asp:Button runat="server" CommandName="Insert" Text="Insert" ID="InsertButton" /><asp:Button runat="server" CommandName="Cancel" Text="Clear" ID="CancelButton" /><br />
                    <br />
                </span>
            </InsertItemTemplate>
            <ItemTemplate>
                <span style="">id:
                    <asp:Label Text='<%# Eval("id") %>' runat="server" ID="idLabel" /><br />
                    headline:
                    <asp:Label Text='<%# Eval("headline") %>' runat="server" ID="headlineLabel" /><br />
                    Image:
                    <asp:Label Text='<%# Eval("Image") %>' runat="server" ID="ImageLabel" /><br />
                    paragraph:
                    <asp:Label Text='<%# Eval("paragraph") %>' runat="server" ID="paragraphLabel" /><br />
                    Sport:
                    <asp:Label Text='<%# Eval("sport") %>' runat="server" ID="SportLabel" /><br />
                    date:
                    <asp:Label Text='<%# Eval("date") %>' runat="server" ID="dateLabel" /><br />
                    lead:
                    <asp:Label Text='<%# Eval("lead") %>' runat="server" ID="leadLabel" /><br />
                    authorID:
                    <asp:Label Text='<%# Eval("authorID") %>' runat="server" ID="authorIDLabel" /><br />
                    <asp:Button ID="EditButton" runat="server" CommandName="Edit" Text="Edit" />
                    <br />
                <br />
                </span>
            </ItemTemplate>
            <LayoutTemplate>
                <div runat="server" id="itemPlaceholderContainer" style=""><span runat="server" id="itemPlaceholder" /></div>
                <div style="">
                    <asp:DataPager runat="server" ID="DataPager1">
                        <Fields>
                            <asp:NextPreviousPagerField ButtonType="Button" ShowFirstPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False"></asp:NextPreviousPagerField>
                            <asp:NumericPagerField></asp:NumericPagerField>
                            <asp:NextPreviousPagerField ButtonType="Button" ShowLastPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False"></asp:NextPreviousPagerField>
                        </Fields>
                    </asp:DataPager>

                </div>
            </LayoutTemplate>
            <SelectedItemTemplate>
                <span style="">id:
                    <asp:Label Text='<%# Eval("id") %>' runat="server" ID="idLabel" /><br />
                    headline:
                    <asp:Label Text='<%# Eval("headline") %>' runat="server" ID="headlineLabel" /><br />
                    Image:
                    <asp:Label Text='<%# Eval("Image") %>' runat="server" ID="ImageLabel" /><br />
                    paragraph:
                    <asp:Label Text='<%# Eval("paragraph") %>' runat="server" ID="paragraphLabel" /><br />
                    Sport:
                    <asp:Label Text='<%# Eval("sport") %>' runat="server" ID="SportLabel" /><br />
                    date:
                    <asp:Label Text='<%# Eval("date") %>' runat="server" ID="dateLabel" /><br />
                    lead:
                    <asp:Label Text='<%# Eval("lead") %>' runat="server" ID="leadLabel" /><br />
                    authorID:
                    <asp:Label Text='<%# Eval("authorID") %>' runat="server" ID="authorIDLabel" /><br />
                    <asp:Button ID="EditButton" runat="server" CommandName="Edit" Text="Edit" />
                    <br />
                <br />
                </span>
            </SelectedItemTemplate>
        </asp:ListView>

    </div>
    </form>
</body>
</html>
ListControl.SelectedValue: 获取列表控件中选定项的值,或选择列表控件中包含指定值的项。继承自ListControl。

在这里,您试图选择一个值字段中不存在的值

SelectedValue=应该可以工作

<asp:DropDownList ID="Sport" runat="server" 
                                    DataSourceID="sportlist" 
                                    DataTextField="sport" 
                                    DataValueField="id"
                                    SelectedValue='<%# Bind("id") %>' >

您是否尝试过使用Eval语句更改dropdownlist SelectedValue?是@Hassansar,但是我仍然收到错误。您可以添加错误描述吗?它说什么?好的,很抱歉标题中提到了。我不确定Bind函数是否区分大小写,但您是否尝试过编写Bindsport而不是Bindsport?也尝试过,但仍然收到错误。我被难住了:/你真正的意思是不要在designer中这样做。这是处理OnDataBinding事件的一个很好的例子。您不必在cs文件中处理数据或处理OnDataBinding事件。dropdownlist Complete的标记足以从现有数据源中选择一个值。你所要做的就是选择一个存在于值字段中的值。我试过了,它允许我编辑下拉框的内容,但是当我单击更新时,我得到了一个新的错误。无法将值NULL插入表C:\USERS\AARON\DOCUMENTS\PROJECT02\APP_DATA\NEWS.MDF.dbo.NEWS'的“Sport”列中;列不允许空值。更新失败。该语句已终止。然后,当我在数据库本身中单击“允许空值”时,我没有收到任何错误,但是数据库不会更新。您不能这样设置。您需要在sql语句中解析它,或者在代码隐藏中处理它。