WPF中添加一个Datagrid使用dataset双向绑定,在第一列中添加一列checkbox用来选择本行,
在最后一列添加一个删除按钮用来删除本行。问题1.我怎么得到这个删除按钮所在行的主键?问题2.我如何遍历被选中的checkbox?...
在最后一列添加一个删除按钮用来删除本行。问题1.我怎么得到这个删除按钮所在行的主键?问题2.我如何遍历被选中的checkbox?
展开
2个回答
展开全部
1 可以根据删除按钮的父级节点的某一个子节点(你主键所在位置)来删除本行
2 你直接遍历datagrid 的每一行的 存在checkbox的那一项 判断是否被选中
2 你直接遍历datagrid 的每一行的 存在checkbox的那一项 判断是否被选中
更多追问追答
追问
我知道思路,但是不会写代码!
你有相关代码吗?
追答
private void btn_Click(object sender, RoutedEventArgs e)
{
Button btn = sender as Button;
string needID= ((DataGrid)btn.Parent).Items[0].ToString();
}
public void delete()
{
for (int i = 0; i < dataGrid1.Items.Count; i++)
{
CheckBox cb = dataGrid1.Items[0] as CheckBox;
if (cb.IsChecked==true)
{
//....
}
}
}
感觉 你老大都八级了 应该不存在这样的问题吧 要不你贴下你的代码 有问题大家讨论下就是了
展开全部
///全选
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 Button1_Click(object sender, EventArgs e)
{
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
if (cbox.Checked == true)
{
Common.ExecuteSql("delete from Employee where ID=" + Convert.ToUInt32(GridView1.DataKeys[i].Value) + "");
}
}
bind();
}
我这是gridview的,基本差不多
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 Button1_Click(object sender, EventArgs e)
{
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
if (cbox.Checked == true)
{
Common.ExecuteSql("delete from Employee where ID=" + Convert.ToUInt32(GridView1.DataKeys[i].Value) + "");
}
}
bind();
}
我这是gridview的,基本差不多
更多追问追答
追问
嗯 这个我知道 一看EventArgs 我就知道不是WPF!
但是你这个是错的,你这个删除全部删除了
我只要删除选中的行,还有一个问题WPF的dataGrid 没有dataGrid.Rows。
追答
wpf的我不清楚,gridview删除一行的有自带的,不需要去定位,定位我用
GridView1.DataKeyNames = new string[] { "id","name" };
DataKey datakey = GridView1.DataKeys[i];
string id= datakey["id"].ToString();
string name= datakey["name"].ToString();
string sqlStr = "delete from stedent where id='" + id+ "'and name='" + name+ "'";
Common.ExecuteSql(sqlStr);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询