1

DropDownList に問題があるようです。通常、選択した DropDownList からテキストを取得し、ボタンのクリック時にコードで比較するボタンがあります。問題は、DropDownList が毎回最初の項目を返すことです。これが私のコードです:

 <asp:DropDownList ID="SubcategoryList" runat="server" 
                DataSourceID="SubCategoryDataSource" DataTextField="SubCategoryName" 
                DataValueField="CategoryId">
  </asp:DropDownList>
<asp:SqlDataSource ID="SubCategoryDataSource" runat="server" 
                ConnectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\ASPNETDB.MDF;Integrated Security=True;User Instance=True" 
                ProviderName="System.Data.SqlClient" 

                SelectCommand="SELECT [SubCategoryName], [CategoryId] FROM [forum_subcategories] WHERE ([CategoryId] = @CategoryId)">
                <SelectParameters>
                    <asp:ControlParameter ControlID="CategoryListSelect" Name="CategoryId" 
                        PropertyName="SelectedValue" Type="Int32" />
                </SelectParameters>
            </asp:SqlDataSource>

string item = SubcategoryList.SelectedItem.Text;

item が選択したアイテムの値を取得するのではなく、ボタンを押すたびに、最初の Item の値を取得します。

ここで何が間違っていますか?

ボタンクリックのコード

protected void Button9_Click( object sender , EventArgs e ) {
        try
        {
            Label4.Visible = true;
            Label4.Text = "Subcategory deleted";

            string itemSelected = SubcategoryList.SelectedItem.Text;
            DataAccess.insertDeleteCategory(itemSelected , "forum_delete_subcategory");
            addForumData();
        }catch(Exception ex)
        {
            Label4.Text = ex.Message;
        }

}
4

0 に答える 0