C# TreeView

增加节点

            TreeNode node1 = new TreeNode();//添加一个节点,这个结点是根节点1。
            node1.Text = "1";
            treeView1.Nodes.Add(node1);

            TreeNode node1_1 = new TreeNode();
            node1_1.Text = "1.1";
            node1.Nodes.Add(node1_1);//在node1下面再添加一个结点1.1。

            TreeNode node1_1_1 = new TreeNode();
            node1_1_1.Text = "1.1.1";
            node1_1.Nodes.Add(node1_1_1);//在node1下面再添加一个结点1.1。

            TreeNode node1_2 = new TreeNode();
            node1_2.Text = "1.2";
            node1.Nodes.Add(node1_2);//在node1下面再添加一个结点1.2。

            TreeNode node2 = new TreeNode();//添加一个节点,这个结点是根节点2。
            node2.Text = "2";
            treeView1.Nodes.Add(node2);
如图:


右键单击Node显示快捷菜单

1、增加contexMenuStrip控件,并编辑控件内容。

2、为treeView控件增加属性。

            treeView1.ContextMenuStrip = contextMenuStrip1;

3、增加treeView右键单击选中事件,目的是右键单击某节点时,节点高亮被选中。

        private void treeView1_MouseClick(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Right)
            {
                treeView1.Focus();
                treeView1.SelectedNode = treeView1.GetNodeAt(e.X, e.Y);
            }
        }
如图:



右键删除Node

1.在contexMenuStrip控件中编辑“删除该级节点”点击事件。

2.在事件中删除该级节点及包含节点。

        private void toolStripMenuItem2_Click(object sender, EventArgs e)
        {
            treeView1.SelectedNode.Remove();
        }
3.存在问题是:

    增加右键删除这种功能时不要将所有节点的“右键快捷菜单”属性赋予同样的事件操作,容易全部删去。多搞几个contexMenuStrip就好,或者代码另加判断,判断是否为不可被删除的Node。具体情况具体分析。


查找指定Node

        private TreeNode FindTreeNode(string str, TreeNode tnParent)
        {
            if (tnParent == null)
                return null;
            if (tnParent.Text == str)
                return tnParent;
            TreeNode tnRet = null;
            foreach (TreeNode tn in tnParent.Nodes)
            {
                tnRet = FindTreeNode(str, tn);
                if (tnRet != null)
                    break;
            }
            return tnRet;
        }

TreeView查找某一节点,通常有两种方法,一种是递归的,一种不是递归,但都是深度优先算法。其中,非递归方法效率高些,而递归算法要简洁一些。尚不了解,后续跟进。(此语出自:http://blog.csdn.net/minsenwu/article/details/7366141)






 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值