c# gridview选中的行ID
怎么获取gridview中选中行的ID啊?List<KeyValuePair<string,DataRow>>currentRows=newList<KeyValuePa...
怎么获取gridview中选中行的ID啊?
List<KeyValuePair<string, DataRow>> currentRows = new List<KeyValuePair<string, DataRow>>();
currentRows.Clear();
我这样就全部清除了,我只想清除选中行的数据,请高手帮个忙,谢谢 展开
List<KeyValuePair<string, DataRow>> currentRows = new List<KeyValuePair<string, DataRow>>();
currentRows.Clear();
我这样就全部清除了,我只想清除选中行的数据,请高手帮个忙,谢谢 展开
5个回答
展开全部
获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个LinkButton。前台 (如果在后台代码中用e.CommandArgument取值的话前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段
<asp:TemplateField HeaderText="操作">
<ItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server" CommandName="QianRu"
CommandArgument='<%# Eval("Id") %>'>签入</asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server" CommandName="QianChu">签出</asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
后台
在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引
protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e){
if (e.CommandName == "QianRu")
{ //取ID的值方法一
GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值
//取ID的值方法二
GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
//此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);
//取ID的值方法三
//因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
int id = Convert.ToInt32(e.CommandArgument.ToString());
}
}
<asp:TemplateField HeaderText="操作">
<ItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server" CommandName="QianRu"
CommandArgument='<%# Eval("Id") %>'>签入</asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server" CommandName="QianChu">签出</asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
后台
在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引
protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e){
if (e.CommandName == "QianRu")
{ //取ID的值方法一
GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值
//取ID的值方法二
GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
//此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);
//取ID的值方法三
//因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
int id = Convert.ToInt32(e.CommandArgument.ToString());
}
}
展开全部
//不等于1时可以删除
IList<string> selectObj = this.FSLGridView1.GetSelectedKeys();
string flagDel = "0";
if (selectObj != null) {
for (int i = 0; i < selectObj.Count; i++) {
if (tblsysNotify.loadDataSet_NH(selectObj[i].ToString()).State != Convert.ToInt32("1")) {
tblsysNotify.delete_NH(selectObj[i].ToString());
flagDel = "1";
} else {
flagDel = "2";
break;
}
}
if (flagDel == "1") {
Utinity.ClientScriptHelper.WriteAlert(this, "删除成功!");
this.FSLGridView1.DataBind();
return;
}
if (flagDel == "2") {
Utinity.ClientScriptHelper.WriteAlert(this, "删除不成功,启用状态不能删除!");
this.FSLGridView1.DataBind();
return;
}
this.FSLGridView1.DataBind();
}
IList<string> selectObj = this.FSLGridView1.GetSelectedKeys();
string flagDel = "0";
if (selectObj != null) {
for (int i = 0; i < selectObj.Count; i++) {
if (tblsysNotify.loadDataSet_NH(selectObj[i].ToString()).State != Convert.ToInt32("1")) {
tblsysNotify.delete_NH(selectObj[i].ToString());
flagDel = "1";
} else {
flagDel = "2";
break;
}
}
if (flagDel == "1") {
Utinity.ClientScriptHelper.WriteAlert(this, "删除成功!");
this.FSLGridView1.DataBind();
return;
}
if (flagDel == "2") {
Utinity.ClientScriptHelper.WriteAlert(this, "删除不成功,启用状态不能删除!");
this.FSLGridView1.DataBind();
return;
}
this.FSLGridView1.DataBind();
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个可以取到你选中行的数据库的编号
string id = GridView1.DataKeys[Convert.ToInt32(e.CommandArgument)].Value.ToString();
然后你可以通过编号直接删除就可以了
string id = GridView1.DataKeys[Convert.ToInt32(e.CommandArgument)].Value.ToString();
然后你可以通过编号直接删除就可以了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
当你选中某一行的时候,你可以得到这行的行号。用行号指定该行就可以删除了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
gridview getall()
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询