本文主要介绍treeView控件中,添加,修改、删除节点的操作,

首先当窗体加载的时候,我们添加上图中所示的节点。

当点击“Delete the Selected”按钮时,被选中的节点将被删除。

当点击“Edit the Selected”按钮式,被选中的节点变成修改状态,此时我们可以对其修改。

其代码如下:

private void Form1_Load(object sender, EventArgs e)
       {
           treeView1.LabelEdit = true;//可编辑状态。

//添加一个节点,这个结点是根节点。
           TreeNode node = new TreeNode();
           node.Text = "hope";
           treeView1.Nodes.Add(node);
           TreeNode node1 = new TreeNode();
           node1.Text = "hopeone";
           TreeNode node11 = new TreeNode();
           node11.Text ="hopeoneone";          
           TreeNode node2 = new TreeNode();
           node2.Text = "hopetwo";
           node1.Nodes.Add(node11);//在node1下面在添加一个结点。
           node.Nodes.Add(node1);//node下的两个子节点。
           node.Nodes.Add(node2);

TreeNode t = newTreeNode("basil");//作为根节点。
           treeView1.Nodes.Add(t);
           TreeNode t1 = new TreeNode("basilone");
           t.Nodes.Add(t1);
           TreeNode t2 = new TreeNode("basiltwo");
           t.Nodes.Add(t2);

}

private void button1_Click(object sender, EventArgs e)
        {//点击该按钮的时候,会移除选中项
           treeView1.Nodes.Remove(treeView1.SelectedNode);
       }

private void button2_Click(object sender, EventArgs e)
       {//点击这个按钮的时候,可以修改选中项

注意:在使用这个属性的时候,必须设置treeView1.LabelEdit =true,否则会提示错误。
           treeView1.SelectedNode.BeginEdit();
       }

C#中Treeview判断选择的节点并执行不同的方法

关于控件Treeview,如何在点击不同的节点(包括父节点和父节点下的子节点)触发不同的事件,执行相应的方法?
方法1:
treeView1_AfterSelect事件就是treeView1中节点被选择触发的事件,e.Node指的是当前选中的节点,e.Node.Nodes指的是当前选中节点的子节点集合。

例如:
        private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
        {
            if (e.Action == TreeViewAction.ByMouse)
            {
                if (e.Node.Parent != null && e.Node.Parent.Index == 0)//当前选中的节点有父节点,并且该父节点在相同级别的父节点中排行第一。
                {  if(e.Node.Index==0)//当前选中节点在所有的兄弟节点中排第 一                   调用相应的方法();
                }
                if(e.Node.Parent==null&&e.Node.Index==4)//表示当前节点没有父节点,并且在兄弟节点中排行第五(由零开始索引)

{

调用相应的方法();
                 }
            }
        }
方法二:通过节点的Name属性来判断具体是哪个节点被选择,并执行相应的方法(这种方法效率高一些)
      private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
         {
              if (e.Action == TreeViewAction.ByMouse)
            {
              if(e.Node.Nodes.Count==0)//说明当前选中节点没有子节点
               if(e.Node.name="aaa")
                  {
                       执行相应的方法();
                  }

else if(e.Node.Name="bbb")
                  {
                      执行相应的方法();
                  }
             }
         }

C# 怎么判断TreeView选中的是子节点 ?并且是属于哪个父节点?

TreeNode selNode = tree.SelectedNode;
if (selNode == null)
{
//防止空引用
return;
}
if (selNode.Parent != null)
{
//为有父亲节点的,
TreeNode parentNode = selNode.Parent;//得到父亲节点 if (selNode.Nodes.Count == 0)
{
//为没有子节点,即选中的节点为叶子节点
}
}
 
 
 
C#.Net中TreeView控件右键选择节点问题处理
 
  1. private void treeView1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e)
  2. {
  3. if(e.Button==MouseButtons.Right)
  4. {
  5. TreeNode tn=treeView1.GetNodeAt(e.X,e.Y);
  6. if(tn!=null)treeView1.SelectedNode = tn;
  7. }
  8. }
 
 
 
 
treeView默认 展开
 
treeView1.ExpandAll();
 
默认选中TreeVIew中的一个节点
 

//先找到你要设置选中的节点

TreeNode tn = treeView1.Nodes[3];

//把要设置的节点给SelectedNode

this.treeView1.SelectedNode = tn;

//this.TreeView1.SelectedNodeIndex="";

 
 
 
 
TreeView,左键单击节点时可修改节点名称
 
TreeView本身可支持左键修改名称
在初始化时设置:
TreeView.LabelEdit = true;
这样应用程序的treeview生成以后就支持单击节点修改。

如果不想左键修改,可在treeView1_MouseDown中设置treeView1.LabelEdit = false; 

右键菜单 重命名
treeView1.LabelEdit = true;
treeView.SelectedNode.BeginEdit();



TreeVIew清空
TreeView.Nodes.Clear()

c#中treeview的使用方法(转 )的更多相关文章

  1. WPF中TreeView.BringIntoView方法的替代方案

    原文:WPF中TreeView.BringIntoView方法的替代方案 WPF中TreeView.BringIntoView方法的替代方案 周银辉 WPF中TreeView.BringIntoVie ...

  2. WPF中TreeView的使用

    因为项目中需要用到TreeView控件,由于是第一次在WPF中用到,因此事先在网上搜了很多关于数据绑定的方法介绍,个人经过实际应用,觉得WPF中的HierarchicalDataTemplate定义模 ...

  3. delphi中Treeview的使用介绍

    今天重点学习了TreeView的使用方法,基本的已经写了,现在主要想说的是如何显示数据库的资料,今天只是做了个较简单的例子,一个父节点下显示数据库中某个field的值.代码如下: procedure ...

  4. JavaScript中Math对象的方法介绍

    1.比较最值方法 比较最值有两种方法,max() 和 min() 方法. 1.1 max() 方法,比较一组数值中的最大值,返回最大值. var maxnum = Math.max(12,6,43,5 ...

  5. Android中锁定文件的方法

    androidSDK中并没有锁定文件相关的api. 但是android是基于linux操作系统的,linux比较底层,灵活性也更大,为了实现锁定文件的效果,大概有以下几种办法: 用chmod命令修改文 ...

  6. jQuery中的事件绑定方法

    在jQuery中,事件绑定方法大致有四种:bind(),live(), delegate(),和on(). 那么在工作中应该如何选择呢?首先要了解四种方法的区别和各自的特点. 在了解这些之前,首先要知 ...

  7. Eclipse中自动提示的方法参数都是arg0,arg1的解决方法

    Eclipse中自动提示的方法参数都是arg0,arg1,就不能根据参数名来推断参数的含义,非常不方便. 解决方法:Preferences->Java->Installed JREs,发现 ...

  8. Power BI官方视频(2) Power BI嵌入到应用中的3种方法

    今天给大家介绍3种将Power BI嵌入到应用中的方法. 本文原文地址:Power BI官方视频(2) Power BI嵌入到应用中的3种方法 Power BI系列文章地址:微软Power BI技术文 ...

  9. JQuery中each()的使用方法说明

    JQuery中each()的使用方法说明 对于jQuery对象,只是把each方法简单的进行了委托:把jQuery对象作为第一个参数传递给jQuery的each方法.换句话说:jQuery提供的eac ...

随机推荐

  1. python基础教程——切片

    获取list或tuple的部分元素: L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack'] L[0:3] ['Michael', 'Sarah', 'Tra ...

  2. 利用vertical-align实现行内元素对齐

    实际项目中,常常会遇到一排行内元素对齐排列的需求,但是往往它们是这样的 我们想要的其实是这样的 曾经我一度不得不使用定位来实现我想要的位置效果,将父元素设置 position:relative ,行内 ...

  3. Mac安装Elasticsearch时提示:No Java runtime present, requesting install.

    没有安装java的童鞋可以先去安装一下,地址:https://www.java.com/zh_CN/ 安装之后还是提示如下错误: ➜ elasticsearch-2.4.3 bin/elasticse ...

  4. kafka 集群搭建

    环境:ubuntu14.04 版本:jdk1.8,zookeeper 3.4.10,kafka 2.11 搭建步骤: 1. 搭建zookeeper集群 参考链接:zookeeper集群搭建 2. 下载 ...

  5. Nginx简介与安装

    | 简介 Nginx是一个高性能的HTTP和反向代理服务器,可以作为负载均衡服务器,也是一个IMAP/POP3/SMTP服务器.它的特点是占有内存少,并发能力强.目前有很多大型公司都在使用Nginx, ...

  6. 跨域请求cookie获取与设置问题

    描述:最近做项目遇到了cookie的问题,项目为前后端分离项目,前台有分外网IP(A外)和内网IP(A内),后台服务只有一个内网IP(B内). 现象:当我前台异步请求发送给后台的时候,后台并不能获取到 ...

  7. 如何打包静态库.framework文件 iOS

    代码调试好了开始打包成sdk,下面是将要打包的FRSDK代码(FRSDK.h暴露在外面有别人调用) 1.创建新工程(Xcode File-New-Project) 2.把下面的红色框的东西移除 3.将 ...

  8. UWP 调用outlook邮箱反馈

    public static async Task FeedbackAsync(string address, string subject, string body) { if (address == ...

  9. salesforce零基础学习(八十四)配置篇: 自定义你的home page layout

    当我们进入salesforce系统或者切换app后,默认第一个看到的就是home页面.home页面简单的来说可以包括左侧(narrow component)和右侧(wide component)两部分 ...

  10. 自学Python全栈开发的第二次笔记(Python需要注意的地方)

    好几天没写blog了,今天整理整理.写blog一定要坚持下去.     Python解释器 #!/usr/bin/env python #-*-coding:utf-8-*-   #  无效的内容,只 ...