c#asp.net怎么让gridview的单元格怎么可编辑

27 篇文章 3 订阅
本文详细介绍了如何在ASP.NET中使用C#实现GridView控件的单元格可编辑功能,包括BoundField设置、CommandField配置及后台事件处理。通过实例演示了数据绑定、编辑、取消和更新的过程。
摘要由CSDN通过智能技术生成

c#asp.net使gridview单元格可编辑,效果图如下所示。  

c#asp.net怎么让gridview的单元格怎么可编辑

方法/步骤

1、

添加BoundField,就是绑定列,设置DataField(绑定的列),HeaderText列标题。添加CommandField列,开启编辑,更新,取消;并绑定事件。操作如图所示。

c#asp.net怎么让gridview的单元格怎么可编辑

 

2、前台代码

<asp:GridView ID="gv"   ForeColor="#333333" GridLines="None"  runat="server" AutoGenerateColumns="False" 

                OnRowEditing="gv_RowEditing" OnRowCancelingEdit="gv_RowCancelingEdit" OnRowUpdating="gv_RowUpdating">

                    <FooterStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />

                <Columns>

                    <asp:BoundField DataField="ID" HeaderText="ID" Visible="false" />

                    <asp:BoundField DataField="测试字段1" HeaderText="测试字段1" />

                    <asp:BoundField DataField="测试字段2" HeaderText="测试此段2" />

                    <asp:CommandField ShowEditButton="True" />

                </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>

3、后台代码:

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

    {

        protected void Page_Load(object sender, EventArgs e)

        {

            if (!IsPostBack)

            {

                DataTable dt = GetDt();

                BindGridView(dt);

            }

        }

 

        private void BindGridView(DataTable dt)

        {

 

            //(重点)设置一个标识(一般是主键)绑定在每一项上去,用于更新数据时,获取主键。(把主键id放在DataKeys)

            this.gv.DataKeyNames = new string[] { "id" };  //这个是绑定在行上的

            gv.DataSource = dt;

            gv.DataBind();

        }

        //实际业务中一般是查询数据库获取

        private DataTable GetDt()

        {

            DataTable dt = new DataTable();

            dt.Columns.Add("ID", typeof(string));

            dt.Columns.Add("测试字段1", typeof(string));

            dt.Columns.Add("测试字段2", typeof(string));

            DataRow r1 = dt.NewRow();

            r1[0] = "1";

            r1[1] = "测试编辑GridView1";

            r1[2] = "测试编辑GridView2";

            dt.Rows.Add(r1);

            return dt;

        }

 

        //点击编辑

        protected void gv_RowEditing(object sender, GridViewEditEventArgs e)

        {

            //设置编辑时的行 等于用户触发事件的这个行

            this.gv.EditIndex = e.NewEditIndex;

            //重新绑定 

            BindGridView(GetDt());

        }

 

        //点击取消时(取消编辑)

        protected void gv_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)

        {

            //设置当前选中行索引为-1(也就是没有)

            this.gv.EditIndex = -1;

 

            //重新绑定 

            BindGridView(GetDt());

 

        }

 

        //编辑时的更新按钮

        protected void gv_RowUpdating(object sender, GridViewUpdateEventArgs e)

        {

            //当前更新的行数

            int index = e.RowIndex;

            //(重点)获取格子里面,第index行,第0号单元格里面第0个控件(也就是TextBox)强转,获取值

            string newsTitle = ((TextBox)this.gv.Rows[index].Cells[0].Controls[0]).Text.ToString();

            string newsContent = ((TextBox)this.gv.Rows[index].Cells[1].Controls[0]).Text.ToString();

            //这里的id是绑定上去的主键

            int id = Convert.ToInt32(this.gv.DataKeys[index].Value);

            string ceshi1 = ((TextBox)(gv.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim();

            string ceshi2 = ((TextBox)(gv.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim();

            //这里实际业务  应该通过id更新字段  更新完后重新绑定

            BindGridView(GetDt());

        }

    }

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值