iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Winform中怎么利用TreeView实现节点定位
  • 618
分享到

Winform中怎么利用TreeView实现节点定位

2023-06-17 21:06:45 618人浏览 安东尼
摘要

winform中怎么利用TreeView实现节点定位,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。WinfORM里面的TreeView节点定位是一种常见的、功能强大的控件,一般

winform中怎么利用TreeView实现节点定位,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

WinfORM里面的TreeView节点定位是一种常见的、功能强大的控件,一般的使用大家可能都是比较熟悉的了,估计我们大多数做TreeView节点定位的时候,一般都是采用循环查找的方法。如下面的方法所示

foreach (Treenode node in this.TreeView1.Nodes)   {      if (node.Text == "要找的节点名称")      {         return node;      }       return null;   }

另外还有一种方法是使用 TreeNode.FromHandle方法来快速定位节点,为了说明如何使用,我们假设有这么一个场景,有一个集团,集团里面有很多公司,每个公司又有一些子公司,

我们需要在每个子公司下面增加一些设备节点或者人员节点。那我们应该如何处理这些节点的显示和定位呢?

首先我们在添加集团这些公司及子公司节点的时候,分别记录这些公司及子公司的树节点信息,放到内存列表中。代码如下所示。

TreeView treeView = this.TreeView1;                          treeView.Nodes.Clear();                          foreach (string key in groupList.Keys)                          {                              TreeNode node = treeView.Nodes.Add(key, key, 0);                              if (!companyHandleDict.ContainsKey(key))                              {                                  companyHandleDict.Add(key, node.Handle);                              }                          }                           foreach (string key in groupList.Keys)                          {                              foreach (string subKey in groupList[key].Keys)                              {                                  TreeNode node = TreeNode.FromHandle(treeView, companyHandleDict[key]);                                  if (node != null)                                  {                                      TreeNode tempNode = node.Nodes.Add(subKey, subKey, 0);                                      if (!subCompanyHandleDict.ContainsKey(key + subKey))                                      {                                          subCompanyHandleDict.Add(key + subKey, tempNode.Handle);                                      }                                  }                              }                          }

记录了这些TreeNode的Handle之后,我们如果要在这些节点上添加子节点的时候,就可以快速定位了。代码如下所示。

foreach (Taxi taxi in taxiDcit.Values)                        {                            string key = taxi.MyInfo.Corporation + taxi.MyInfo.Filialy;                            TreeNode node = TreeNode.FromHandle(treeView, subCompanyHandleDict[key]);                            if (node != null)                            {                                TreeNode subNode = new TreeNode(taxi.MyBrand, 1, 2);                                subNode.Tag = "vehicle";                                node.Nodes.Add(subNode);                            }                         }

看完上述内容,你们掌握Winform中怎么利用TreeView实现节点定位的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: Winform中怎么利用TreeView实现节点定位

本文链接: https://www.lsjlt.com/news/293079.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL怎么更新字段长度
    要更新MySQL表中的字段长度,可以使用ALTER TABLE语句。以下是更新字段长度的示例: ALTER TABLE table_...
    99+
    2024-05-14
    mysql
  • sql如何修改表字段长度
    要修改表字段的长度,可以使用ALTER TABLE语句,然后使用MODIFY COLUMN来修改字段的长度。以下是一个示例: ALT...
    99+
    2024-05-14
    sql
  • mysql数据量太大如何解决
    有几种方法可以解决MySQL数据量过大的问题: 数据库分区:将数据库表按照某种规则进行分区,分成多个小表,可以提高查询速度和管理...
    99+
    2024-05-14
    mysql
  • MySQL单表数据量过大如何解决
    在MySQL中,当单表的数据量过大时,可以采取以下几种方法来解决问题: 使用索引:在表的字段上创建适当的索引,可以提高查询效率,...
    99+
    2024-05-14
    mysql
  • mysql导出数据量过大如何解决
    当导出的数据量过大时,可以尝试以下方法来解决问题: 使用数据库工具:使用数据库管理工具如Navicat或MySQL Workbe...
    99+
    2024-05-14
    mysql
  • mysql中log_bin的作用是什么
    在MySQL中,log_bin是二进制日志文件的名称,用于记录所有对数据库进行更改的操作,如插入、更新、删除等。这些二进制日志文件可...
    99+
    2024-05-14
    mysql
  • mysql中log_bin的特点有哪些
    log_bin是MySQL的二进制日志文件,用于记录所有对数据库的修改操作,包括插入、更新、删除等。 log_bin文件是M...
    99+
    2024-05-14
    mysql
  • mysql rpm包安装的方法是什么
    要在Linux系统上安装MySQL RPM包,可以按照以下步骤操作: 下载MySQL的RPM包:你可以从MySQL官方网站下载适...
    99+
    2024-05-14
    mysql
  • mysql rpm包安装后怎么使用
    安装MySQL RPM包后,您可以通过以下步骤来使用MySQL: 启动MySQL服务:使用以下命令来启动MySQL服务: sud...
    99+
    2024-05-14
    mysql
  • lxml中怎么处理XML命名空间默认值
    在lxml中处理XML命名空间的默认值可以通过使用xpath()方法和register_namespace()方法来实现。...
    99+
    2024-05-14
    lxml
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作