asp.net datagrid视图行选择到文本框中

时间:2015-04-21 13:10:56

标签: c# asp.net sql-server datagrid

当用户点击网格视图中的编辑按钮时,我需要帮助将行选择放入文本框中,我有事件,并会显示我尝试过的代码。 我在visual studio 2013和sql server 2012上运行。

txtname.Text = gridview.Rows[gridview.SelectedIndex].Cells[1].Text;

txtname.Text = gridview.Rows[gridview.SelectedRow].Cells[1].Text;

[screen] http://imgur.com/WCsvnLB,cLdMeQN

3 个答案:

答案 0 :(得分:1)

而不是gridview.SelectedIndex你应该有一个事件arg并抓住它的索引。来自docs

protected void TaskGridView_RowEditing(object sender, GridViewEditEventArgs e)
  {
    //Set the edit index.
    TaskGridView.EditIndex = e.NewEditIndex;
    //Bind data to the GridView control.
    BindData();
  }

所以你的意思是:

protected void gridView_RowEditing(object sender, GridViewEditEventArgs e)
{
   txtname.Text = gridview.Rows[e.NewEditIndex].Cells[1].Text;
}

答案 1 :(得分:1)

首先使用以下代码创建Gridview

 <asp:GridView ID="GV" runat="server" AutoGenerateColumns="false"  OnRowEditing="GV_RowEditing" DataKeyNames="id">
        <Columns>
            <asp:TemplateField HeaderText="Username">
                <ItemTemplate>
                    <asp:Label ID="Label1" runat="server" Text='<%#Eval("Column1")%>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Password">
                <ItemTemplate>
                    <asp:Label ID="Label2" runat="server" Text='<%#Eval("Column2")%>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Action">
                <ItemTemplate>
                    <asp:LinkButton ID="LinkButton1" runat="server" CommandName="edit" OnClick="LinkButton1_Click" >Edit</asp:LinkButton>
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>

然后生成gridview的行编辑事件,并在其中编写此代码

 string id = GV.DataKeys[e.NewEditIndex].Value.ToString();
    string select = "select * from tblLogin where id ='"+Convert.ToInt16(id)+"'";
    ds = gs.select(select);
    if (ds.Tables[0].Rows.Count > 0)
    {
       lblName.Text= ds.Tables[0].Rows[0]["Column1"].ToString();
        lblPass.Text=ds.Tables[0].Rows[0]["Column2"].ToString();
    }

希望这会有所帮助

答案 2 :(得分:0)

所以我使用了你的两个答案的组合,并想出了一个可行的方法:

int id = Convert.ToInt32(gridview.DataKeys[e.NewEditIndex].Value);
    txtid.Text = id.ToString();
    txtname.Text = gridview.Rows[id].Cells[3].Text;
    txtadd.Text = gridview.Rows[id].Cells[4].Text;
    txtcountry.Text = gridview.Rows[id].Cells[5].Text;
    txtcity.Text = gridview.Rows[id].Cells[6].Text;
    txtpin.Text = gridview.Rows[id].Cells[7].Text;

让我知道你的想法,如果这是错误的编码,请告诉我。

感谢名单