C# winform 中展开Treeview节点的问题。。。有分

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# winform 中展开Treeview节点的问题。。。有分相关的知识,希望对你有一定的参考价值。

怎么控制加载进去让TreeView的节点默认展开到第三级,其他的全部+,不展开,求源码,高手详解。。。
发我邮箱381855568@qq.com

public void treeTool(TreeViewItem item,int grade)

if (grade < 2 && item.Items.Count > 0)

for (int i = 0; i < item.Items.Count; i++)

TreeViewItem nowItem = item.Items[i] as TreeViewItem;
nowItem.IsExpanded = true;
treeTool(nowItem, grade++);



else if (grade > 2 && item.Items.Count>0)

for (int i = 0; i < item.Items.Count; i++)

TreeViewItem nowItem = item.Items[i] as TreeViewItem;
nowItem.IsExpanded = false;
treeTool(nowItem, grade++);






没 winform 不知道 正确性怎么样
大概就这么个意思 用递归的
具体样式什么的 自己改下
参考技术A c#好长时间 没碰了,循环2次到2级节点,将其属性改一下就可以了 参考技术B 我晕你。 有个一方法来定指 展开还是收缩。 参考技术C 都搞忘了

c#、winform、treeview 部分节点加图片

【部门表】是存放在MS SQL SERVER 中,数据结构中的字段有“部门编号”、“部门名”、“父节点编号”分别表示“dpid"、、“dpname”、“dppid”,用树形treeview控件展示出来,用递归的方法邦定数据:(方法 BindTreeView() 放在页面初始加载时 或 放在刷新按钮上 )
//邦定treeview
public void BindTreeView()

sqlconn.GetConn().Open();//打开数据库连接

#region //初始化treeview信息
this.treeView1.Nodes.Clear();
TreeNode root = new TreeNode("Nexscien 部门列表");//添加根节点
root.Tag = 0;

root.NodeFont = new Font("宋体", 15, FontStyle.Underline);
this.treeView1.ItemHeight = 30;
this.treeView1.Nodes.Add(root);
#endregion
SqlDataAdapter sqldap = new SqlDataAdapter(msl.tvpid(), sqlconn.GetConn());
DataSet ds = new DataSet();
sqldap.Fill(ds);
DataView dv = ds.Tables[0].DefaultView;

foreach (DataRowView row in dv)

string name = row["dpname"].ToString().Trim();
int id = Convert.ToInt32(row["dpid"].ToString().Trim());
TreeNode tn = new TreeNode(name);
tn.Tag = row["dpid"].ToString();//记录部门ID

tn.NodeFont = new Font("宋体", 13, FontStyle.Underline);
TV_Addchildnodes(tn, id);
this.treeView1.Nodes.Add(tn);

sqlconn.GetConn().Close();


//子节点递归循环
public void TV_Addchildnodes(TreeNode node, int nodeID)

SqlDataAdapter sqldap = new SqlDataAdapter(msl.tvcid(nodeID), sqlconn.GetConn());
DataSet ds = new DataSet();
sqldap.Fill(ds);
DataView dv = ds.Tables[0].DefaultView;

foreach (DataRowView row in dv)

string name = row["dpname"].ToString().Trim();
int id = Convert.ToInt32(row["dpid"].ToString().Trim());
TreeNode tn = new TreeNode(name);
tn.Tag = row["dpid"].ToString();

tn.NodeFont = new Font("宋体", 11, FontStyle.Underline);
TV_Addchildnodes(tn, id);
node.Nodes.Add(tn);
//tn.Expand();



【员工表】数据结构中的字段有“员工编号”、“员工姓名”、“部门编号”、“父节点编号”分别表示“pid”、“pname”、“dpid”、“dppid”。
【部门表】和【员工表】在程序中的逻辑关系是先添加部门才能添加员工并对该员工分配部门。
问:在treeview 控件加载邦定部门表时,无论父节点、子节点,判断每一个节点如果有员工存在则让该节点添加图片,这一功能如何实现 ????

参考技术A 这个你要配合另一个控件来使用,ImageList这个控件,是图片的集合,然后就能引用了追问

怎么配合,你配合一下呗,完整点

追答

就是imagelist这个控件有一个属性,是引用图片的集合

然后

之后添加就能添加图片了,之后再treeview 的

属性引用之后就可以了

追问

这样做只是其中一步吧,还需要添加个SQL判断语句呢,这样才能让它实现有员工的节点用指定的图标,没员工的用另一指定图标

追答

对啊,这就是添加图片的思想啊,其他的你就根据你的程序自己编啊,那样才有乐趣啊

参考技术B 我记得treeview有个属性是可以加图片的,你好好找找看

以上是关于C# winform 中展开Treeview节点的问题。。。有分的主要内容,如果未能解决你的问题,请参考以下文章

C# winform treeview 节点展开状态的图标设置

c#、winform、treeview 部分节点加图片

c#的winform TreeView控件中,展开不同的节点,右边显示不同的内容,该怎么做啊,请帮帮我吧,谢谢~

C# winform开发中,如果treeview的节点太多,导致加载很慢,怎么做可以提给效率?

winform中,TreeView如何只展开一级节点

winform 中Treeview控件怎样选中父节点时子节点全部展开,选中其他父节点时原先展开的关闭