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;
}
}