今天,主要弄了一下对于树型控件的一些方法,以及异步加载。
参考:

http://www.cnblogs.com/greatverve/archive/2012/03/23/winform-treeview.html

下面是TreeView的一些用法

private void BindTreeView()
{
treeView1.LabelEdit = false;//不可编辑
//添加结点
TreeNode root = new TreeNode();
root.Text = "根节点";
//一级
TreeNode node1 = new TreeNode();
node1.Text = "";
TreeNode node2 = new TreeNode();
node2.Text = "";
//二级
TreeNode node11 = new TreeNode();
node11.Text = "";
TreeNode node12 = new TreeNode();
node12.Text = "";
TreeNode node21 = new TreeNode();
node21.Text = "";
TreeNode node22 = new TreeNode();
node22.Text = "";
//二级加入一级
node1.Nodes.Add(node11);
node1.Nodes.Add(node12);
node2.Nodes.Add(node21);
node2.Nodes.Add(node22);
//一级加入根
root.Nodes.Add(node1);
root.Nodes.Add(node2);
//
treeView1.Nodes.Add(root);
}
private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
{
if (treeView1.SelectedNode != null)
{
MessageBox.Show(treeView1.SelectedNode.Text);
}
}

基本用法有了,下面,就把我写的异步加载列表的方法写进去了,因为是参考网上的方法临时 写的,可能会有些不足之处,也有可以改进,优化的一些方法

 DataTable dt = data.createDT();
#region 树的异步加载
/// <summary>
/// 载入根节点
/// </summary>
public void make_rootView()
{ foreach (DataRow row in dt.Select("module_fatherid='M01'"))
{
TreeNode tn = new TreeNode();
string sk=row["module_id"].ToString();
tn.Text = row["module_name"].ToString();
treeView1.Nodes.Add(tn);
DataRow[] row2=(dt.Select("module_fatherid='" + sk + "'"));
if (row2.Count()!=)
{ TreeNode tn1 = new TreeNode();
tn1.Text = "";
tn.Nodes.Add(tn1);
}
}
}
/// <summary>
/// 载入子节点
/// </summary>
/// <param name="node_id"></param>
/// <param name="node"></param>
public void make_view(string node_id,TreeNode node)
{
node.Nodes.Clear();
foreach (DataRow row in dt.Select("module_fatherid='"+node_id+"'"))
{
TreeNode tn = new TreeNode();
string sk = row["module_id"].ToString();
tn.Text = row["module_name"].ToString();
node.Nodes.Add(tn); if ((dt.Select("module_fatherid='" + sk + "'")).Count() != )
{
TreeNode tn1 = new TreeNode();
tn1.Text = "";
tn.Nodes.Add(tn1);
}
}
}
/// <summary>
/// 查找父节点的ID
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
public void make_NodeView(object sender, TreeViewCancelEventArgs e)
{
TreeNode tn = e.Node;
string node_id = "";
foreach (DataRow row in dt.Select("module_name='" + tn.Text + "'"))
{
node_id = row["module_id"].ToString();
}
make_view(node_id, tn);
}
#endregion private void treeView1_BeforeExpand(object sender, TreeViewCancelEventArgs e)
{
make_NodeView(sender, e); }

在刚载入时调用

 private void Form1_Load(object sender, EventArgs e)
{ make_rootView(); }

在树型控件的事件treeView1_BeforeExpand调用

private void treeView1_BeforeExpand(object sender, TreeViewCancelEventArgs e)
{ make_NodeView(sender, e); }

下面是我的数据源,我是根据下面这个表格的结构来写代码 ,根据结构的不一样,代码 也应做相应的改变

public class data
{
public static DataTable createDT()
{
DataTable dt = new DataTable();
dt.Columns.Add("module_id");
dt.Columns.Add("module_name");
dt.Columns.Add("module_fatherid");
dt.Columns.Add("module_url");
dt.Columns.Add("module_order"); dt.Rows.Add("C1", "全国", "", "", "");
dt.Rows.Add("M01", "广东", "C1", "", ""); dt.Rows.Add("M0101", "深圳", "M01", "", "");
dt.Rows.Add("M010101", "南山区", "M0101", "", "");
dt.Rows.Add("M010102", "罗湖区", "M0101", "", "");
dt.Rows.Add("M010103", "福田区", "M0101", "", "");
dt.Rows.Add("M010104", "宝安区", "M0101", "", "");
dt.Rows.Add("M010105", "龙岗区", "M0101", "", ""); dt.Rows.Add("M01010301", "上梅林", "M010103", "", "");
dt.Rows.Add("M01010302", "下梅林", "M010103", "", "");
dt.Rows.Add("M01010303", "车公庙", "M010103", "", "");
dt.Rows.Add("M01010304", "竹子林", "M010103", "", "");
dt.Rows.Add("M01010305", "八卦岭", "M010103", "", "");
dt.Rows.Add("M01010306", "华强北", "M010103", "", ""); dt.Rows.Add("M0102", "广州", "M01", "", "");
dt.Rows.Add("M010201", "越秀区", "M0102", "", "");
dt.Rows.Add("M010202", "海珠区", "M0102", "", "");
dt.Rows.Add("M010203", "天河区", "M0102", "", "");
dt.Rows.Add("M010204", "白云区", "M0102", "", "");
dt.Rows.Add("M010205", "黄埔区", "M0102", "", "");
dt.Rows.Add("M010206", "荔湾区", "M0102", "", "");
dt.Rows.Add("M010207", "罗岗区", "M0102", "", "");
dt.Rows.Add("M010208", "南沙区", "M0102", "", "");
return dt;
}
}

以上表结构是从网上摘录下来的!!!

winform TreeView的一些用法以及异步加载的更多相关文章

  1. winform异步加载数据到界面

    做一个学习记录. 有两个需求: 1.点击按钮,异步加载数据,不卡顿UI. 2.把获取的数据加载到gridview上面. 对于需求1,2,代码如下: public delegate void ShowD ...

  2. jsTree 的简单用法--异步加载和刷新数据

    首先这两个文件是必须要引用的,还有就是引用 jQuery 文件就不说了: <link href="/css/plugins/jsTree/style.min.css" rel ...

  3. WinForm中异步加载数据并使用进度条

    在WinForm程序中,有时会因为加载大量数据导致UI界面假死,这种情况对于用户来说是非常不友好的.因此,在加载大量数据的情况下,首先应该将数据加载放在另一线程中进行,这样保证了UI界面的响应:其次可 ...

  4. WinForm中使用BackgroundWorker异步加载数据并使用进度条

    在WinForm程序中,有时会因为加载大量数据导致UI界面假死,这种情况对于用户来说是非常不友好的.因此,在加载大量数据的情况下,首先应该将数据加载放在另一线程中进行,这样保证了UI界面的响应:其次可 ...

  5. require.ensure的用法;异步加载-代码分割;

    webpack异步加载的原理 webpack ensure相信大家都听过.有人称它为异步加载,也有人说做代码切割,那这 个家伙到底是用来干嘛的?其实说白了,它就是把js模块给独立导出一个.js文件的, ...

  6. js回调与异步加载的用法

    以前还是菜鸟的时候(虽然现在依然很菜 -_-|| )对异步加载与回调函数的技术无比向往,但也一直没有使用过,这次因为页面逻辑太过复杂,一堆请求逻辑,如果还是用顺序请求,页面的速度... 领导又要挠头了 ...

  7. ListView异步加载图片,完美实现图文混排

    昨天参加一个面试,面试官让当场写一个类似于新闻列表的页面,文本数据和图片都从网络上获取,想起我还没写过ListView异步加载图片并实现图文混排效果的文章,so,今天就来写一下,介绍一下经验. Lis ...

  8. ExtJS入门教程05,grid的异步加载数据

    上一篇演示了extjs grid的基本用法,并加载了本地数据.今天我们将演示如何加载异步数据. 所谓异步,就是通过ajax的方式将服务器端的数据加载到我们的grid中.为了提供数据,我们先定义一个数据 ...

  9. volley 应用 GET POST请求 图片异步加载

    package com.example.volleydemo; import java.util.HashMap; import java.util.Map; import org.json.JSON ...

随机推荐

  1. JavaScript零基础学习系列二

    条件控制 if(条件){//语句块}如果条件(小括号里面的)满足true.那么才会执行大括号里面的代码,如果条件不满足(false),那么不执行,注意:有可能代码不会执行. 例如: if(3>1 ...

  2. UISearchBar控件-让我们来搞定!(转)

    转载自:http://blog.sina.com.cn/s/blog_7b9d64af0101dfg8.html     最近用到搜索功能.于是,经过不断的研究,终于,有点懂了. 那就来总结一下吧,好 ...

  3. Java基础-包名和文件夹名字必须对应

    .java文件夹中的包名必须与物理文件夹的对应. 如果修改包名或者文件夹名,双方都需要同时更新.

  4. 搭建maven项目

    一.新建项目 点击"Maven Project",如果没有的话在"Other"里面 勾选这个选项,这样可以建立一个没有多余文件的简单项目(如果这个时候直接建立w ...

  5. TypeScript Declaration Merging(声明合并)

    TypeScript中有一些独特的概念,来自需要描述JavaScript对象类型发生了哪些变化.举个例子,最为独特的概念就是"声明合并".理解了这个概念将会对你在当前JavaScr ...

  6. WebUploader UEditor chrome 点击上传文件选择框会延迟几秒才会显示 反应很慢

    chrome52.0.2743.80以上, accept: { title: 'Images', extensions: 'jpg,jpeg,png', mimeTypes: 'image/*' } ...

  7. yuv420转rgb 及 rgb转bmp保存

    /// <summary> /// 将一桢 YUV 格式的图像转换为一桢 RGB 格式图像. /// </summary> /// <param name="y ...

  8. Web jquery表格组件 JQGrid 的使用 - 全部代码

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  9. hibernate的集中持久化方法的区别

    一.预备知识 在所有之前,说明一下,对于hibernate,它的对象有三种状态,transient.persistent.detached 下边是常见的翻译办法: transient:瞬态或者自由态 ...

  10. 第3月第11天 vs2005调试 ace编译

    1.vs2005调试 http://blog.csdn.net/u010797208/article/details/40452797 2.macbook ace编译 小坑: 源代码clockid_t ...