在gridview中实现删除选定行 删除键在gridview外

各位大哥哥,大姐姐好,初学.Net,想实现这样一个功能,选中gridview中的某一行或多行,实现删除功能;选中其中一行实现修改功能。截图如下:点击上面截图中的修改,显示... 各位大哥哥,大姐姐好,初学.Net,想实现这样一个功能,选中gridview中的某一行或多行,实现删除功能;选中其中一行实现修改功能。截图如下:点击上面截图中的修改,显示下面的截图。现在全选,添加的功能已经实现,剩下删除选定行和修改选定行的功能不能实现,请哪位大哥哥,大姐姐指点一下,要详细啊,嘿嘿!小女子感激不尽. 展开
 我来答
PengLi588
推荐于2016-05-23 · TA获得超过180个赞
知道答主
回答量:167
采纳率:0%
帮助的人:81.5万
展开全部

这个功能我实现过  这是 我的代码

后台代码:

using System;

using System.Data;

using System.Configuration;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.Data.SqlClient;

public partial class Default5 : System.Web.UI.Page

{

    SqlConnection sqlcon;

    string strCon = "Data Source=(local);Database=北风贸易;Uid=sa;Pwd=sa";

    protected void Page_Load(object sender, EventArgs e)

    {

        if (!IsPostBack)

        {

            bind();

        }

    }

    protected void CheckBox2_CheckedChanged(object sender, EventArgs e)

    {

        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)

        {

            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");

            if (CheckBox2.Checked == true)

            {

                cbox.Checked = true;

            }

            else

            {

                cbox.Checked = false;

            }

        }

    }

    protected void Button2_Click(object sender, EventArgs e)

    {

        sqlcon = new SqlConnection(strCon);

        SqlCommand sqlcom;

        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)

        {

            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");

            if (cbox.Checked == true)

            {

                string sqlstr = "delete from  where 身份证号码='" + GridView1.DataKeys[i].Value + "'";

                sqlcom = new SqlCommand(sqlstr, sqlcon);

                sqlcon.Open();

                sqlcom.ExecuteNonQuery();

                sqlcon.Close();

            }

        }

        bind();

    }

    protected void Button1_Click(object sender, EventArgs e)

    {

        CheckBox2.Checked = false;

        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)

        {

            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");

            cbox.Checked = false;

        }

    }

    public void bind()

    {

        string sqlstr = "select top 5 * from ";

        sqlcon = new SqlConnection(strCon);

        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);

        DataSet myds = new DataSet();

        sqlcon.Open();

        myda.Fill(myds, "tb_Member");

        GridView1.DataSource = myds;

        GridView1.DataKeyNames = new string[] { "身份证号码" };

        GridView1.DataBind();

        sqlcon.Close();

    }

}

前台主要代码:

<asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False"

                        CellPadding="3" Font-Size="9pt" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px">

                        <FooterStyle BackColor="White" ForeColor="#000066" />

                        <Columns>

                             <asp:TemplateField>

                                <ItemTemplate>

                                    <asp:CheckBox ID="CheckBox1" runat="server" />

                                </ItemTemplate>

                            </asp:TemplateField>

                             <asp:BoundField DataField="身份证号码" HeaderText="用户ID" SortExpression="身份证号码" />

                            <asp:BoundField DataField="姓名" HeaderText="用户姓名" SortExpression="姓名"/>

                            

                            <asp:BoundField DataField="家庭住址" HeaderText="家庭住址" SortExpression="家庭住址"/>

                                

                        </Columns>

                        <RowStyle ForeColor="#000066" />

                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />

                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />

                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />

                    </asp:GridView>

                     <asp:CheckBox ID="CheckBox2" runat="server" AutoPostBack="True" Font-Size="9pt" OnCheckedChanged="CheckBox2_CheckedChanged"

                        Text="全选" />

                    <asp:Button ID="Button1" runat="server" Font-Size="9pt" Text="取消" OnClick="Button1_Click" />

                    <asp:Button ID="Button2" runat="server" Font-Size="9pt" Text="删除" OnClick="Button2_Click" />

zjlahbf
2009-06-21 · 超过46用户采纳过TA的回答
知道小有建树答主
回答量:234
采纳率:0%
帮助的人:108万
展开全部
在 checkbox 上设置一个onclick事件

点击的时候吧ID传入 一个input里 input runat

每个ID用符号分开 列如 1,2,3,4

然后删除的时候 拆分字符串

delete from table where id in (id1,id2,id3)

就是这样 明白了吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友22442ffa4
2009-06-21
知道答主
回答量:7
采纳率:0%
帮助的人:7.1万
展开全部
//删除按钮的点击事件里这样写就可以
public void ButtonDelete(object sender,EventArgs e)
{
foreach (GridViewRow gr in GridView1.Rows)
{
if (gr.RowType == DataControlRowType.DataRow)
{
if (((CheckBox)gr.Cells[0].Controls[0]).Checked)
{
//这里写下你删除这行数据的代码
}
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Play_nada
2009-06-21 · TA获得超过129个赞
知道答主
回答量:46
采纳率:0%
帮助的人:42.5万
展开全部
这个说起来话长了,删除时遍历gridview看哪行被选中,选中的话把ID取出来,用一条delete from table where id in (id1,id2,id3)这样的语句进行删除,编辑时把ID取出来 并把下面的那个显示出来不就得了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友2b52746
2009-06-22 · 超过50用户采纳过TA的回答
知道小有建树答主
回答量:206
采纳率:0%
帮助的人:83.3万
展开全部
呵呵,这个网上的例子很多的,给你一个gridview技巧的网址,里面的例子都很好,基本上改一改就可以自己用了。
http://hi.baidu.com/fuyujian0420/blog/item/ed40c03dc738bcea3c6d9714.html
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式