treeview 控件使用和数据绑定

1 篇文章 0 订阅

一、TreeViewe 是由多个类来定义的,TreeView组件是由命名空间“System.Windows.Froms”中的“TreeView”类来定义的,而其中的节点(即Node),是由命名空间“System.Windows.Froms”中的“TreeNode”来定义的。所以在程序中创建一个TreeVirew对象,其实只是创建了一个可以防止检点的“容器”。而在这个容器中加入一个节点,其实就是加入了从“TreeNode”类中创建的一个节点对象;同样删除一个节点,也就是删除一个“TreeNode”对象。

二、 C#操作TreeView组件中的一些常用方法以及具体实现:

可以总结为三种基本操作:加入子节点、加入兄弟节点和删除节点

1.加入子节点

所谓子节点,就是处于选定节点的下一级节点。加入子节点的具体过程是:首先要在TreeView组件中定位要加入的子节点的位置,然后创建一个节点对象,然后利用TreeVeiw类中对节点的加入方法(即:Add ( )方法),加入此节点对象。
//首先判断是否选定组件中的位置
if (treeView1.SelectedNode == null)
{
MessageBox.Show(“请选择一个节点”, “提示信息”,
MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
//创建一个节点对象,并初始化
TreeNode tmp;
tmp = new TreeNode(“节点名称”);
//在TreeView组件中加入子节点
treeView1.SelectedNode.Nodes.Add(tmp);
treeView1.SelectedNode = tmp;
treeView1.ExpandAll();
}
  2.加入兄弟节点
  所谓兄弟节点,就是在选定的节点的平级的节点。加入兄弟节点的方法和加入子节点的方法基本一致,只是在最后的实现方法上有着略微的区别。加入兄弟节点的具体步骤,首先也是要确定要加入的兄弟节点所处的位置,接着定义一个节点对象,最后调用TreeView类中对兄弟节点加入的方法,加入此节点对象。加入兄弟节点和加入子节点的最大区别就在于这最后一步。希望读者能够注意。下面是在TreeView组件加入一个兄弟
//首先判断是否选定组件中节点的位置
if (treeView1.SelectedNode == null)
{
MessageBox.Show(“请选择一个节点”, “提示信息”,
MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
//创建一个节点对象,并初始化
TreeNode tmp;
tmp = new TreeNode(textBox1.Text);
//在TreeView组件中加入兄弟节点
treeView1.SelectedNode.Parent.Nodes.Add(tmp);
treeView1.ExpandAll();
}
  3.删除节点

删除节点就是删除TreeView组件中选定的节点,删除节点可以是子节点,也可以是兄弟节点,但无论节点的性质如何,必须保证要删除的节点没有下一级节点,否则必须先删除此节点中的所有下一级节点,然后再删除此节点。删除节点比起上面的二个操作要显得略微简单,具体方法是:首先判断要删除的节点是否存在下一级节点,如果不存在,就调用TreeView类中的Remove ( )方法,就可以删除节点了。下面是删除TreeView组件中节点的具体代码:

//判断选定的节点是否存在下一级节点
if ( treeView1.SelectedNode.Nodes.Count == 0 )
//删除节点
treeView1.SelectedNode.Remove ( ) ;
else
MessageBox.Show ( “请先删除此节点中的子节点!” , “提示信
息” , MessageBoxButtons.OK ,
MessageBoxIcon.Information ) ;
  4.TreeView组件的一些其他常用操作:

< I > .展开所有节点:

要展开TreeView组件中的所有节点,首先就要把选定的节点指针定位在TreeView组件的根节点上,然后调用选定组件的ExpandAll方法就可以了,下面是具体代码:

1
2
3
4
//定位根节点
treeView1.SelectedNode = treeView1.Nodes [ 0 ] ;
//展开组件中的所有节点
treeView1.SelectedNode.ExpandAll ( ) ;
    < II > .展开选定节点的下一级节点:

由于只是展开下一级节点,所以就没有必要用ExpandAll ( )方法了。展开下一级节点只需要调用Expand ( )方法就可以了,下面是具体的实现代码:

1
treeView1.SelectedNode.Expand ( ) ;

< III > .折叠所有节点:

折叠所有节点和展开所有节点是一组互操作,具体实现的思路也大致相同,折叠所有节点也是首先要把选定的节点指针定位在根节点上,然后调用选定组件的Collapse ( )就可以了,下面是具体的实现代码:
//定位根节点
treeView1.SelectedNode = treeView1.Nodes [ 0 ] ;
//折叠组件中所有节点
treeView1.SelectedNo
using System ;
using System.Drawing ;
using System.Collections ;
using System.ComponentModel ;
using System.Windows .Forms ;
using System.Data ;
namespace 全面掌握TreeView组件的使用方法
{
/// Form1 的摘要说明。
public class Form1 : Form
{
private TreeView treeView1 ;
private Button button1 ;
private Button button2 ;
private Button button3 ;
private MenuItem menuItem2 ;
private MenuItem menuItem3 ;
private MenuItem menuItem4 ;
private ContextMenu contextMenu1 ;
private TextBox textBox1 ;
private Label label1 ;
/// 必需的设计器变量。
private System.ComponentModel.Container components = null ;
public Form1 ( )
{
//初始化窗体中的组件
InitializeComponent ( ) ;
}
/// 清理所有正在使用的资源。
protected override void Dispose ( bool disposing )
{
if ( disposing )
{
if ( components != null )
{
components.Dispose ( ) ;
}
}
base.Dispose ( disposing ) ;
}
private void InitializeComponent ( )
{
   //初始化代码(略)
}
[ STAThread ]
static void Main ( )
{
Application.Run ( new Form1 ( ) ) ;
}
private void AddChildNode ( )
{
//首先判断是否选定组件中的位置
if ( treeView1.SelectedNode == null )
{
MessageBox.Show ( “请选择一个节点” , “提示信息” ,
MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
}
else
{
if ( textBox1.Text != “” )
{
//创建一个节点对象,并初始化
TreeNode tmp ;
tmp = new TreeNode ( textBox1.Text ) ;
//在TreeView组件中加入子节点
treeView1.SelectedNode.Nodes.Add ( tmp ) ;
treeView1.SelectedNode = tmp ;
treeView1.ExpandAll ( ) ;
}
else
{
MessageBox.Show ( “TextBox组件必须填入节点名称!” , “提示信息” , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
return ;
}
}
}
private void AddParent ( )
{
//首先判断是否选定组件中节点的位置
if ( treeView1.SelectedNode == null )
{
MessageBox.Show ( “请选择一个节点” , “提示信息” , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
}
else
{
if ( textBox1.Text != “” )
{
//创建一个节点对象,并初始化
TreeNode tmp ;
tmp = new TreeNode ( textBox1.Text ) ;
//在TreeView组件中加入兄弟节点
treeView1.SelectedNode.Parent.Nodes.Add ( tmp ) ;
treeView1.ExpandAll ( ) ;
}
else
{
MessageBox.Show ( “TextBox组件必须填入节点名称!” , “提示信息” , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
return ;
}
}
TreeNode tnode = new TreeNode ( textBox1.Text ) ;
}
private void treeView1_MouseDown ( object sender ,
MouseEventArgs e )
{
if ( e.Button == MouseButtons.Right )
contextMenu1.Show ( this , new Point ( e.X , e.Y ) ) ;
}
private void button1_Click ( object sender ,
System.EventArgs e )
{
treeView1.SelectedNode.Expand ( ) ;
}
private void menuItem2_Click ( object sender ,
System.EventArgs e )
{
AddChildNode ( ) ;
}
private void menuItem3_Click ( object sender ,
System.EventArgs e )
{
AddParent ( ) ;
}
private void menuItem4_Click ( object sender ,
System.EventArgs e )
{
//判断选定的节点是否存在下一级节点
if ( treeView1.SelectedNode.Nodes.Count == 0 )
//删除节点
treeView1.SelectedNode.Remove ( ) ;
else
MessageBox.Show ( “请先删除此节点中的子节点!” , “提示信
息” , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
}
private void button2_Click ( object sender ,
System.EventArgs e )
{
//定位根节点
treeView1.SelectedNode = treeView1.Nodes [ 0 ] ;
//展开组件中的所有节点
treeView1.SelectedNode.ExpandAll ( ) ;
}
private void button3_Click ( object sender ,
System.EventArgs e )
{
//定位根节点
treeView1.SelectedNode = treeView1.Nodes [ 0 ] ;
//折叠组件中所有节点
treeView1.SelectedNode.Collapse ( ) ;
}
}
}
  四、数据绑定

默认展开树的级别;0是不展开;1是展开一级;

public partial class _Default : System.Web.UI.Page
{
private void LoadTree(TreeNode parentNode)
{
List list = new chinabf().selectByCode(parentNode.Value);
if (list.Count == 0)
{
return;
}
foreach (ChinaStates item in list)
{
TreeNode childNode = new TreeNode();
childNode.Text = item.AreaName;
childNode.Value = item.AreaCode;
parentNode.ChildNodes.Add(childNode);
LoadTree(childNode);
}
}
protected void Page_Load(object sender, EventArgs e)
{
TreeNode root = new TreeNode();
root.Text = “中国”;
root.Value = “0001”;
TreeView1.Nodes.Add(root);
LoadTree(root);
}

TreeNode root = new TreeNode();
root.Text = "汉企数据通软件有限公司";
root.Value = "H001";
root.SelectAction = TreeNodeSelectAction.None;
TreeView1.Nodes.Add(root);
List<Department> list = new Function().SelectPart();
List<Worker> data=new List<Worker>();
foreach (Department item in list)
{
    TreeNode firstNode = new TreeNode();
    firstNode.Text = item.Department1;
    firstNode.Value = item.DepartCode;
    firstNode.SelectAction = TreeNodeSelectAction.None;
    root.ChildNodes.Add(firstNode);
    List<Worker>arr= new Function().SelectWorker(item.Department1);
    foreach (Worker workers in arr)
    {
        TreeNode child = new TreeNode();
        child.Text = workers.Wname;
        child.Value = workers.Wid.ToString();
        child.SelectAction = TreeNodeSelectAction.None;
        firstNode.ChildNodes.Add(child);
    }
}

}
  3.遍历所有子节点,找出选中项
protected void Button1_Click(object sender, EventArgs e)
{
List listNodes = new List();
foreach (TreeNode node in TreeView1.Nodes)
{
if (node != null)
{
FindCheckNode(node, listNodes);
}
else
{
return;
}
}
}

private void FindCheckNode(TreeNode node, List listNodes)
{
if (node.Checked)
{
listNodes.Add(node);
}

foreach (TreeNode childnode in node.ChildNodes)
{

    FindCheckNode(childnode, listNodes);
}

}
\\\\\\\\\\\\\\\\\\\\\\\\\\

1、CheckBoxes 属性:指示是否在树视图控件中的树节点旁显示复选框。(默认值:False)

2、FullRowSelect 属性:当 FullRowSelect 为 true 时,选择突出显示将跨越树视图的整个宽度,即整个显示区域的宽度而不仅仅是树节点标签的宽度。如果 ShowLines 设置为 true,则将忽略 FullRowSelect 属性。(默认值:False)

3、HideSelection 属性:指示选定的树节点是否即使在树视图已失去焦点时仍会保持突出显示。(默认值:True)

4、HotTracking 属性:如果 HotTracking 属性设置为 true,那么当鼠标指针移过每个树节点标签时,树节点标签都将具有超级链接的外观。Underline 字体样式将应用于 Font 而 ForeColor 将设置为蓝色,从而使标签显示为链接。注意:如果 CheckBoxes 属性设置为 true,HotTracking 属性将失效。(默认值:False)

5、Indent 属性:设置每个子树节点级别的缩进距离(以像素为单位)。(默认值:19)

6、ItemHeight 属性:设置树视图控件中每个树节点的高度。(默认值:16)

7、Nodes 属性:获取分配给树视图控件的树节点集合。这个属性是TreeView 控件最重要的属性之一,我们下文将会对它进行更加的详细的说明。

8、PathSeparator 属性:树节点路径(TreeNode.FullPath 属性)所使用的分隔符串,默认为反斜杠字符 (),树节点路径包括一组由 PathSeparator 分隔符串分隔的树节点标签。标签的范围为根树节点到所需的树节点。如下代码我们可以获得当前选中的节点的路径:

MessageBox.Show(TreeView1.SelectedNode.FullPath)

9、SelectedNode 属性:获取或设置当前在树视图控件中选定的树节点,如果没有选定任何节点,则 SelectedNode 属性则为Nothing。

10、ShowLines 属性:指示是否在树视图控件中的树节点之间绘制连线。(默认值:True)

11、ShowPlusMinus 属性:指示是否在包含子树节点的树节点旁显示加号 (+) 和减号 (-) 按钮。(默认值:True)

12、ShowRootLines 属性:指示是否在树视图根处的树节点之间绘制连线。(默认值:True)

  • 1
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值