GridView1.DataKeys[e.RowIndex].Value 是什么含义?

举个例子来说吧 你将一个student表绑定到grid上 这个表里有一些字段 包括id 姓名 学号 等等等等
grid的DataKey 属性设置了 datakey=“学号”
下边开始解释问题

GridView1.DataKeys是什么?

GridView有一个属性是DataKey 当将数据表绑定到GridView时,设置数据表的一列为DataKey 即GridView.datakey=“学号”
msdn讲DataKey解释为 获取 DataKeyCollection 对象,它存储数据列表控件中每个记录的键值。
其实 就是将 [学号] 这列作为列关键字 列标识

e.RowIndex是什么含义?

能够使用e.rowindex 说明 应该是grid的row相关事件 其中的e就是事件的触发者 也就是当前行 e.rowindex 也就是当前行的索引 行号 第几行的“几”

GridView1.DataKeys[e.RowIndex]是一个数组吗?

GridView1.DataKeys是一个数组 存储的是数据表中的一列的值 这一列 就是设为DataKeys的一列 即[学号]这一列
GridView1.DataKeys[e.RowIndex]则是学号这一列这个数组中的一个值 索引为当前行的行号
也就是说GridView1.DataKeys[e.RowIndex]是当前行所对应的数据行这一行 的 学号这个datakey

GridView1.DataKeys[e.RowIndex].Value是什么?

这里就是当前行所对应的数据行这一行 的 学号这个datakey 所存储的值 即当前选择这个学生的学号

GridView1.DataKeys[GridView1.SelectedIndex].Value.ToString()

GridView1.DataKeys[e.RowIndex].Value.ToString() 的区别

是不同事件中获取当前选中行行号的不同方法
在grid的行相关事件中 可以直接用e来得到当前行 但是在非grid行事件中 作为e的事件触发对象就不是行 所以要用GridView1.SelectedIndex 来获取当前选中行的行号

对于C#和ASP.NET,GridView控件是一个非常常用的控件,用于显示和编辑数据。以下是一个简单的示例,演示如何使用GridView实现增删改查功能。 首先,在ASP.NET页面中添加一个GridView控件: ```html <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"> <Columns> <asp:BoundField DataField="id" HeaderText="ID" /> <asp:BoundField DataField="name" HeaderText="Name" /> <asp:BoundField DataField="age" HeaderText="Age" /> <asp:CommandField ShowEditButton="True" ShowDeleteButton="True" /> </Columns> </asp:GridView> ``` 然后,在后台代码中,需要添加以下事件处理程序: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { BindData(); } } protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e) { GridView1.EditIndex = e.NewEditIndex; BindData(); } protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e) { GridView1.EditIndex = -1; BindData(); } protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) { string id = GridView1.DataKeys[e.RowIndex].Value.ToString(); string name = ((TextBox)GridView1.Rows[e.RowIndex].FindControl("txtName")).Text; string age = ((TextBox)GridView1.Rows[e.RowIndex].FindControl("txtAge")).Text; // TODO: 更新数据库中的数据 GridView1.EditIndex = -1; BindData(); } protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e) { string id = GridView1.DataKeys[e.RowIndex].Value.ToString(); // TODO: 从数据库中删除数据 BindData(); } protected void btnAdd_Click(object sender, EventArgs e) { string name = txtName.Text; string age = txtAge.Text; // TODO: 将数据插入到数据库中 BindData(); } private void BindData() { // TODO: 从数据库中获取数据,并绑定到GridView控件中 } ``` 在代码中,`BindData`方法用于从数据库中获取数据,并将其绑定到GridView控件中。`Page_Load`方法在页面首次加载时调用`BindData`方法。`GridView1_RowEditing`、`GridView1_RowCancelingEdit`、`GridView1_RowUpdating`和`GridView1_RowDeleting`方法分别处理编辑、取消编辑、更新和删除操作。`btnAdd_Click`方法用于新增数据。 以上示例并没有实现完整的增删改查功能,需要根据具体需求进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值