C#winfrom 中 TreeView 控件中带checkbox,怎么实现在父节点上打勾,选中全部子节点?
如图,点击帮助checkbox选中的时候,三个子节点checkbox全部选中,去掉父节点上的勾子节点全部取消,,求助,有高分。。。...
如图,点击帮助checkbox选中的时候,三个子节点checkbox全部选中,去掉父节点上的勾子节点全部取消,,求助,有高分。。。
展开
5个回答
展开全部
楼主没有考虑“如果勾选所有子节点,父节点也会勾选;如果某子节点取消勾选,则所有父节点也取消勾选”,下面的代码能全做到:
//设置标志,防止死循环
bool check = false;
//节点勾选后事件,如果更改某一节点状态会自动触发,所以在后面的方法中无需递归
private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
{
if(check==false)
setchild(e.Node);
setparent(e.Node);
check = false;
}
//设置子节点状态
private void setchild(TreeNode node)
{
foreach (TreeNode child in node.Nodes)
{
child.Checked = node.Checked;
}
check = true;
}
//设置父节点状态
private void setparent(TreeNode node)
{
if (node.Parent != null)
{
//如果当前节点状态为勾选,则需要所有兄弟节点都勾选才能勾选父节点
if (node.Checked)
foreach (TreeNode brother in node.Parent.Nodes)
{
if (brother.Checked == false)
return;
}
node.Parent.Checked = node.Checked;
}
}
//设置标志,防止死循环
bool check = false;
//节点勾选后事件,如果更改某一节点状态会自动触发,所以在后面的方法中无需递归
private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
{
if(check==false)
setchild(e.Node);
setparent(e.Node);
check = false;
}
//设置子节点状态
private void setchild(TreeNode node)
{
foreach (TreeNode child in node.Nodes)
{
child.Checked = node.Checked;
}
check = true;
}
//设置父节点状态
private void setparent(TreeNode node)
{
if (node.Parent != null)
{
//如果当前节点状态为勾选,则需要所有兄弟节点都勾选才能勾选父节点
if (node.Checked)
foreach (TreeNode brother in node.Parent.Nodes)
{
if (brother.Checked == false)
return;
}
node.Parent.Checked = node.Checked;
}
}
展开全部
实现该功能最好还是用无刷新技术。
通过jqury的强大selector功能就可以轻易的实现
1、需要添加jquery引用
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
2、假设你的TreeView的id="TreeView1",那么,在你的页面添加这段代码就ok了。
<script type="text/javascript">
$(function () {
$('#TreeView1').find(':checkbox').bind('click', function () {
var checked = this.checked;
$(this).parents("table").find("+ div").find(':checkbox').each(function () {
this.checked = checked;
});
});
});
</script>
通过jqury的强大selector功能就可以轻易的实现
1、需要添加jquery引用
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
2、假设你的TreeView的id="TreeView1",那么,在你的页面添加这段代码就ok了。
<script type="text/javascript">
$(function () {
$('#TreeView1').find(':checkbox').bind('click', function () {
var checked = this.checked;
$(this).parents("table").find("+ div").find(':checkbox').each(function () {
this.checked = checked;
});
});
});
</script>
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
{
TreeNode node = e.Node;
foreach (TreeNode item in node.Nodes)
{
item.Checked = e.Node.Checked;
}
}
{
TreeNode node = e.Node;
foreach (TreeNode item in node.Nodes)
{
item.Checked = e.Node.Checked;
}
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的图看不到。设父checkbox的名字叫cbxParent,其余三个叫checkbox1,checkbox2,checkbox3。
在cbxParent的Click事件中写代码
{
checkbox1.Checked=cbxParent.Checked;
checkbox2.Checked=cbxParent.Checked;
checkbox3.Checked=cbxParent.Checked;
}
在cbxParent的Click事件中写代码
{
checkbox1.Checked=cbxParent.Checked;
checkbox2.Checked=cbxParent.Checked;
checkbox3.Checked=cbxParent.Checked;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
满意答案考虑的挺全面,但代码存在两个问题:
1)在子节点状态修改的代码中,check = true;应该放在{}内且child.Checked = node.Checked;的前面,这是因为当节点的状态发生改变时会立刻调用AfterCheck事件;
2)在修改父节点的状态中应该在node.Parent.Checked = node.Checked;的前面应该check = true;,目的是防止死循环。
1)在子节点状态修改的代码中,check = true;应该放在{}内且child.Checked = node.Checked;的前面,这是因为当节点的状态发生改变时会立刻调用AfterCheck事件;
2)在修改父节点的状态中应该在node.Parent.Checked = node.Checked;的前面应该check = true;,目的是防止死循环。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询