WPF中添加一个Datagrid使用dataset双向绑定,在第一列中添加一列checkbox用来选择本行,
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了WPF中添加一个Datagrid使用dataset双向绑定,在第一列中添加一列checkbox用来选择本行,相关的知识,希望对你有一定的参考价值。
在最后一列添加一个删除按钮用来删除本行。问题1.我怎么得到这个删除按钮所在行的主键?问题2.我如何遍历被选中的checkbox?
1 可以根据删除按钮的父级节点的某一个子节点(你主键所在位置)来删除本行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)
//....
感觉 你老大都八级了 应该不存在这样的问题吧 要不你贴下你的代码 有问题大家讨论下就是了
我才开始做 Wpf,谢谢你 。我给你追加分。
追答不用 你看看行不行 我也没测试 有问题 你直接HI 我吧
追问这个确实有问题,你帮我调一下吧!我百度Hi 添加你为好友了!
参考技术A ///全选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);
谢谢你!
以上是关于WPF中添加一个Datagrid使用dataset双向绑定,在第一列中添加一列checkbox用来选择本行,的主要内容,如果未能解决你的问题,请参考以下文章
WPF中,我使用了datagrid,我想请问下当我向数据库添加了新的数据,我该怎么刷新datagrid里面的数据?