简单的小记录,省得去看控件属性详情了,基本常用的属于就几个

先是判断根节点是否存在控件中,如果不存在则创建,之前要添加了节点同样的方法

把根节点传到子节点的方法中,再判断是否在根节点里存在子节点,如果不存在则创建,

最后利用控件的双击事件获取当前选中的节点的内容。

 using System;
 using System.Collections.Generic;
 using System.ComponentModel;
 using System.Data;
 using System.Drawing;
 using System.Linq;
 using System.Text;
 using System.Windows.Forms;
 using System.Text.RegularExpressions;
 using DotNet4.Utilities;
 using System.Threading;

 namespace TreeviewDome
 {
     public partial class Form1 : Form
     {
         public Form1()
         {
             InitializeComponent();
         }

         private void button1_Click(object sender, EventArgs e)
         {
             Thread t = new Thread(ThreadProcessUrl);
             t.IsBackground = true;
             t.Start();
         }

         /// <summary>
         /// 根据页数生成Url
         /// </summary>
         private void ThreadProcessUrl()
         {
             int page = Convert.ToInt32(txtPages.Text);
             )
             {
                 ; i <= page; i++)
                 {
                     string address = string.Format(txtUrl.Text, i);
                     GetHtml(address);
                 }
             }
             else
             {
                 GetHtml(txtUrl.Text);
             }
         }

         /// <summary>
         /// 批量下载网页处理链接
         /// </summary>
         /// <param name="urls">传入Url</param>
         public void GetHtml(string urls)
         {
             HttpHelper http = new HttpHelper();
             HttpItem item = new HttpItem();
             item.URL = urls;
             HttpResult result = http.GetHtml(item);
             string html = result.Html;
             Regex r = new Regex("(?<=<span class=\"n-img\"><a href=\").*?(?=\")");
             MatchCollection m = r.Matches(html);
             if (!tvUrlList.Nodes.ContainsKey(urls)) //判断是否存在节点,不存在则创建
             {
                 TreeNode root = new TreeNode(urls); //创建根节点
                 this.Invoke(new Action(delegate
                     {
                         tvUrlList.Nodes.Add(root);
                     }));

                 foreach (Match mh in m)
                 {
                     TreeNode node = new TreeNode(mh.Value);
                     if (!root.Nodes.ContainsKey(mh.Value)) //判断根节点是否存在子节点,不存在则创建
                     {
                         this.Invoke(new Action(delegate
                             {
                                 root.Nodes.Add(node); //在根节点下添加子节点
                             }));
                     }
                 }
             }

         }

         /// <summary>
         /// 双击选中节点处理
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void treeView1_NodeMouseDoubleClick(object sender, TreeNodeMouseClickEventArgs e)
         {
             //获取被单击的节点
             TreeNode tn = e.Node;
             string ss=tvUrlList.TopNode.Text;
             if (tn.Text ==ss)
             {
                 MessageBox.Show("这个是不想要的");
             }
             else
             {
                 MessageBox.Show("当前选中的是:"+tn.Text);
             }
         }
     }
 }

下载:https://files.cnblogs.com/files/ncle/TreeviewDome.rar

TreeView简单的动态加载数据的更多相关文章

  1. echarts官网上的动态加载数据bug被我解决。咳咳/。

    又是昨天,为什么昨天发生了这么多事.没办法,谁让我今天没事可做呢. 昨天需求是动态加载数据,画一个实时监控的折线图.大概长这样. 我屁颠屁颠的把代码copy过来,一运行,caocaocao~bug出现 ...

  2. AppCan学习笔记----关闭页面listview动态加载数据

    AppCan页面关闭 AppCan 的页面是由两个HTML组成,如果要完全关闭的话需要在主HTML eg.index.html中关闭,关闭方法:appcan.window.close(-1); 管道 ...

  3. [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件

    页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...

  4. 微信小程序(五) 利用模板动态加载数据

    利用模板动态加载数据,其实是对上一节静态数据替换成动态数据:

  5. mui 动态加载数据出现的问题处理 (silder轮播组件 indexedList索引列表 下拉刷新不能继续加载数据)

    mui-slider 问题:动态给mui的图片轮播添加图片,轮播不滚动. 解决:最后把滚动轮播图片的mui(".mui-slider").slider({interval: 300 ...

  6. ASP.NET MVC动态加载数据

    ASP.NET MVC动态加载数据,一般的做法是使用$.each方法来循环产生tabel: 你可以在html时先写下非动态的部分:  Source Code 上图中,有一行代码: <tbody ...

  7. js实现滚动条来动态加载数据

    主要angular2+es6 data:Array<any> //展示的数据 allData:Array<any> //全部的数据 size:number = 10 //每次动 ...

  8. js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的

    js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样 ...

  9. js动态加载数据并合并单元格

    js动态加载数据合并单元格, 代码如下所示,可复制直接运行: <!DOCTYPE HTML> <html lang="en-US"> <head> ...

随机推荐

  1. 枚举类TimeUnit

    枚举类TimeUnit 全路径为 java.util.concurrent.TimeUnit TimeUnit 主要用于通知基于时间的方法如何解释给定的计时参数 举例如下 如果 lock 不可用,则以 ...

  2. 一个简单小巧的CSV读取类

    最近在基于亚马逊MWS API做一些服务,需要读取亚马逊返回的报表,是一个按照\t分割的文本,所以就封装了一个简单小巧的CsvReader类 使用方法 使用方法非常简单,只需要传递一个stream子类 ...

  3. ng-transclude

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. Dynamic Inversions 50个树状数组

    Dynamic Inversions Time Limit: 30000/15000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others ...

  5. NOIP2017SummerTraining0713

    个人感受:这套题是真的难,以至于,拿了130分就第三了(说来羞耻,真的不想---) 问题 A: 乐曲创作 时间限制: 1 Sec  内存限制: 256 MB提交: 370  解决: 58[提交][状态 ...

  6. Button标签自动刷新问题

    在form表单中,button标签在IE浏览器 type类型默认是button ,而在其他浏览器默认是submit. 解决方法1: 设置类型type="button" <bu ...

  7. 浅谈PHP7的新特性

    我以前用过的php的最高版本是php5.6.在换新工作之后,公司使用的是PHP7.据说PHP7的性能比之前提高很多.下面整理下php7的新特性.力求简单了解.不做深入研究. 1.变量类型声明 函数的参 ...

  8. C#中 计时器用法

    有时候我们会需要计算某段代码运行的时间比如一个sql查询,记录一段代码所花费的时间等等代码如下: System.Diagnostics.Stopwatch watch = new System.Dia ...

  9. 压缩SQLServer数据库日志的一个存储过程

    use master --注意,此存储过程要建在master数据库中 go if exists (select * from dbo.sysobjects where id = object_id(N ...

  10. redis的发布订阅模式pubsub

    前言 redis支持发布订阅模式,在这个实现中,发送者(发送信息的客户端)不是将信息直接发送给特定的接收者(接收信息的客户端),而是将信息发送给频道(channel),然后由频道将信息转发给所有对这个 ...