GridView и код DetailsView за обновлением DetailsView - PullRequest
2 голосов
/ 14 июня 2011

Я потратил весь день, пытаясь сделать это, используя CODE BEHIND, но безуспешно, поэтому я прошу некоторый код C #.

По сути, у меня есть GV и DV в отношениях мастер / деталь.GV отображает идентификатор и имя.Если я нажимаю «Выбрать» в строке GV, я хочу видеть ее идентификатор, имя и адрес в DV.Я знаю, как заставить это работать декларативно в файле aspx.Но в коде C # я не знаю, как действовать в этой функции:

protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName.Equals("Select"))
    {

    //  PLEASE GIVE ME THE CODE HERE TO BIND THE DETAILSVIEW. THANKS!
    // I am using a sqldatasource if it makes any difference

    }
 }

1 Ответ

4 голосов
/ 14 июня 2011

Вот общее решение, показывающее, как этого добиться, обратите внимание, что это решение не является чрезвычайно безопасным, но я полагаю, что вы получите его.Пожалуйста, прокомментируйте, если что-то неясно.

Кодовый код:

protected void gv_RowCommand(object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName == "Select")
    {
        GridViewRow selected = gv.Rows[Convert.ToInt32(e.CommandArgument)];
        List<ThatClass> cList = new List<ThatClass>();
        cList.Add(new ThatClass(selected.Cells[0].Text, selected.Cells[1].Text));
        dv.DataSource = cList;
        dv.DataBind();
    }
}

Разметка:

<asp:GridView ID="gv" runat="server" AutoGenerateColumns="false" OnRowCommand="gv_RowCommand">
    <Columns>
        <asp:BoundField DataField="A" HeaderText="A"/>
        <asp:BoundField DataField="B" HeaderText="B" />
        <asp:CommandField ShowSelectButton="true" />
    </Columns>
</asp:GridView>

<asp:DetailsView runat="server" ID="dv">
</asp:DetailsView>

К вашему сведению: я связал GV, используя Список:

protected void Page_Load(object sender, EventArgs e)
{
    List<ThatClass> cList = new List<ThatClass>();
    cList.Add(new ThatClass("123", "abc"));
    cList.Add(new ThatClass("456", "def"));
    gv.DataSource = cList;
    gv.DataBind();
}
...