当前位置: 移动技术网 > IT编程>开发语言>c# > Winform中Treeview实现按需加载的方法

Winform中Treeview实现按需加载的方法

2019年07月18日  | 移动技术网IT编程  | 我要评论
本文实例讲述了winform中treeview实现按需加载的方法,非常具有实用价值。分享给大家供大家参考。具体分析如下: 最近项目里用到treeview,原先设计的是一开

本文实例讲述了winform中treeview实现按需加载的方法,非常具有实用价值。分享给大家供大家参考。具体分析如下:

最近项目里用到treeview,原先设计的是一开始就把所有数据都加载到treeview里,后来发现客户的数据量实在太大,加载所有数据要2分钟,这个是客户没法接受的。后来就考虑到用户也不是一开始就要看所有的数据,用户也是一层一层地展开,所以我们就考虑是不是可以实现以当用户展开某个结点时才加载当前结点下面的数据。一番查找后,发现treeview有beforeexpand事件可以实现我们的需求。

下面介绍具体的实现代码:

1. 首先只加载各部门(结点)的信息

复制代码 代码如下:
list<string> m_departments = new list<string>() { "湖北.黄石", "湖北.鄂州", "湖北.武汉" };
private void adddepartments(list<string> departments)
{
     if (m_root == null)
     {
         var root = departments[0].split('.')[0];
         m_root = new treenode(root);
         m_root.tag = root;
         treeview1.nodes.add(m_root);
     }
     foreach (var department in departments)
     {
         var parent = m_root;
         var dts = department.split('.');
         for (int i = 1; i < dts.length; i++)
         {
             if (!m_orgnodemanager.containskey(dts[i]))
             {
                 var child = new treenode(dts[i],1,1);
                 child.tag = dts[i];
                 child.tooltiptext = department;
                 m_orgnodemanager.add(dts[i], child);
                 parent.nodes.add(child);
                 parent = child;
             }
         }
         parent.nodes.add("");
     }
}

这里要注意,每个结点加完后,要加上一个空的子结点parent.nodes.add(""); 不然就没有那个加号让你点了。

2. 实现beforeexpand事件

复制代码 代码如下:
private void treeview1_beforeexpand(object sender, treeviewcanceleventargs e)
{
     treenode curentnode = e.node;
     if (curentnode.imageindex == 1)
     {
         curentnode.nodes.clear();
         foreach (var user in m_usermanager)
         {
             if (user.value.tostring() == curentnode.tooltiptext.tostring())
             {
                 treenode usernode = new treenode(user.key);
                 curentnode.nodes.add(usernode);
             }
         }
     }
}

希望本文所述对大家的c#程序设计有所帮助。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网