Установить значение для выпадающего списка

У меня проблемы с моим заданием. Я пытаюсь установить значение для dropdownlist в GridView, когда я редактирую данные в этом. Но когда я отправляю свое задание своему другу, он сказал, что может запустить его без ошибок (он использует Visual Studio 2010). Я использую Visual Studio 2008 и 2010, но я не могу запустить свой код. Пожалуйста, помогите мне.

 SqlConnection cn=new SqlConnection(System.Web.Configuration.WebConfigurationManager.ConnectionStrings["cn"].ToString());
protected void Page_Load(object sender, EventArgs e)
{
    if (IsPostBack == false)
    {
        LoadProduct();
    }
}
public  DataSet LoadCategory()
{
    SqlDataAdapter da = new SqlDataAdapter("select * from categories", cn);
    DataSet ds = new DataSet();
    da.Fill(ds);
    return ds;
}
private void LoadProduct()
{
    //throw new NotImplementedException();
    SqlDataAdapter da=new SqlDataAdapter("select * from products,categories where products.categoryID=categories.categoryID",cn);
    DataTable db=new DataTable();
    da.Fill(db);
    GridView1.DataSource=db;
    GridView1.DataBind();
}

protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
{
    GridView1.EditIndex = -1;
    LoadProduct();
}
protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
{
    Literal ltr=GridView1.Rows[e.NewEditIndex].FindControl("Literal1") as Literal;
    string categoryname = ltr.Text;
    GridViewRow row=GridView1.Rows[e.NewEditIndex];
    LoadProduct();
    DropDownList ddl = row.Cells[3].Controls[1] as DropDownList;
    ddl.DataSource = LoadCategory().Tables[0];// when I run there is a error. "Object reference not set to an instance of an object"
    ddl.DataTextField = "categoryName";
    ddl.DataValueField = "categoryID";
    ddl.DataBind();
    ddl.Items.FindByText(categoryname).Selected = true;        
}
0
Назначение? Это домашнее задание?
добавлено автор jwiscarson, источник
И почему вы не можете запустить его? Пожалуйста, предоставьте нам исключение.
добавлено автор Amy, источник

2 ответы

Попробуй это

ddl.ClearSelection();
ddl.Items.FindByText(categoryname).Selected = true;
1
добавлено

не можете ли вы сделать это так, чтобы найти свой DDL?

DropDownList ddl = GridView1.Rows[e.NewEditIndex].FindControl("ddl") as DropDownList;
ddl.DataSource = LoadCategory().Tables[0];
0
добавлено
DotNetRuChat
DotNetRuChat
2 992 участник(ов)

Чат русскоязычного .NET сообщества http://dotnet.ru/ Вам могут быть интересны: @dotnetchat, @cilchat, @fsharp_chat, @pro_net, @xamarin_russia, @microsoftstackjobs, @uwp_ru Флуд в @dotnettalks

Microsoft Stack Jobs
Microsoft Stack Jobs
1 788 участник(ов)

Work & freelance only Microsoft Stack. Feed https://t.me/Microsoftstackjobsfeed Чат про F#: @Fsharp_chat Чат про C#: @CSharpChat Чат про Xamarin: @xamarin_russia Чат общения:@dotnettalks

pro.net
pro.net
710 участник(ов)

Обсуждение .NET Framework и всего, что с ним связано. Правила: не флудить не по теме, уважать ваших коллег и никакой рекламы (объявления о вакансиях можно согласовать с @AlexFails). Флудилка: @dotnettalks Участник @proDOT

Microsoft Developer Community Chat
Microsoft Developer Community Chat
584 участник(ов)

Чат для разработчиков и системных администраторов Microsoft Developer Community. __________ Новостной канал: @msdevru __________ Баним за: оскорбления, мат, рекламу, флуд, флейм, спам, NSFW контент, а также большое количество оффтоп тем. @banofbot

.NET Talks: Force Push Masters
.NET Talks: Force Push Masters
490 участник(ов)

Свободный чат .NET разработчиков. Правила: t.me/dotnettalks/56823 Вам могут быть интересны: @dotnetruchat, @dotnetchat, @cilchat, @fsharp_chat, @pro_net, @dotnetgroup, @xamarin_russia, @microsoftstackjobs, @uwp_ru http://combot.org/chat/-1001128250813

.NET Chat Убежище
.NET Chat Убежище
246 участник(ов)

Чат .NET разработчиков под эгидой MSK/SPB .NET Community Group Вам могут быть интересны: @fsharp_chat, @dotnetruchat, @cilchat, @xamarin_russia, @microsoftstackjobs, @dotnetgroup Флуд в @dotnettalks

.NET CIL Chat
.NET CIL Chat
54 участник(ов)

.NET CIL (aka IL aka MSIL)