c# WPF中的TreeView使用详解

 更新时间:2021年03月17日 09:55:31   作者:Yhzwei  
这篇文章主要介绍了c# WPF中的TreeView使用详解,帮助大家更好的理解和学习使用c#技术,感兴趣的朋友可以了解下

在wpf中实现treeview的功能,可能看到很多分享的都是简单的绑定,仅此记录自己完成的功能。

前台

<TreeView x:Name="chapterTree" Grid.Column="0" SelectedItemChanged="chapterTree_SelectedItemChanged" PreviewMouseRightButtonDown="chapterTree_PreviewMouseRightButtonDown" FontSize="14" ItemsSource="{Binding Path=Nodes}" >
      
      <TreeView.ContextMenu>
       <ContextMenu>
        <MenuItem Header="保存" Name="btnAlterData" Click="btnAlterData_Click" />
        <MenuItem Header="新增兄弟节点" Name="btnSaveData" Click="btnSaveData_Click"/>
        <MenuItem Header="新增子节点" Name="btnSaveSonData" Click="btnSaveSonData_Click"/>
        <MenuItem Header="删除" Name="btnDdeleteData" Click="btnDdeleteData_Click"/>
        <MenuItem Header="上移一位" Name="btnUp" Click="btnUp_Click"/>
        <MenuItem Header="下移一位" Name="btnDown" Click="btnDown_Click"/>
       </ContextMenu>
      </TreeView.ContextMenu>
      <TreeView.ItemTemplate>
       <HierarchicalDataTemplate DataType="{x:Type c:OrderModel}" ItemsSource="{Binding Path=ChildNodes}">
        <Label Content="{Binding Path=OrderName}"/>
       </HierarchicalDataTemplate>
      </TreeView.ItemTemplate>
     </TreeView>

后台

CommandModel cm;

  public Command()
  {
   InitializeComponent();
   cm = new CommandModel();
   chapterTree.ItemsSource = cm.Nodes;

  }

新建了CommandModel页面用来绑定数据(从数据库提取的数据,转换成了list)

public event PropertyChangedEventHandler PropertyChanged;
  private ObservableCollection<OrderModel> nodes = new ObservableCollection<OrderModel>();
  public ObservableCollection<OrderModel> Nodes
  {
   get { return nodes; }
   set
   {
    nodes = value;
    if (PropertyChanged != null)
     PropertyChanged(this, new PropertyChangedEventArgs("Nodes"));
   }
  }
  
  public CommandModel()
  {
   Initiate();
  }
  private void Initiate()
  {
   using (SQLiteConnection con = new SQLiteConnection(MainWindow.sb.ToString()))
   {
    DataTable table = new DataTable("MyTable");
    var reader = con.ExecuteReader("SELECT * FROM OrderData Order by OrderID");
    table.Load(reader);
    ObservableCollection<OrderModel> _nodes = new ObservableCollection<OrderModel>();
    _nodes = ConvertToList(table);

    //ShowTreeView();
    Nodes = getChildNodes(0, _nodes);

   }
  }

  private ObservableCollection<OrderModel> getChildNodes(long parentID, ObservableCollection<OrderModel> nodes)
  {
   List<OrderModel> a = new List<OrderModel>(nodes.Where(x => x.ParentID == parentID).ToList());
   ObservableCollection<OrderModel> mainNodes =new ObservableCollection<OrderModel>(a);
   List<OrderModel> b = new List<OrderModel>(nodes.Where(x => x.ParentID != parentID).ToList());
   ObservableCollection<OrderModel> otherNodes =new ObservableCollection<OrderModel>(b);
   foreach (OrderModel node in mainNodes)
    node.ChildNodes = getChildNodes(node.ID, otherNodes);
   return mainNodes;
  }




  #region datatable转list

  /// <summary>
  /// datatable转list
  /// </summary>
  /// <param name="dt"></param>
  /// <returns></returns>
  public static ObservableCollection<OrderModel> ConvertToList(DataTable dt)
  {

   // 定义集合
   ObservableCollection<OrderModel> ts = new ObservableCollection<OrderModel>();

   // 获得此模型的类型
   Type type = typeof(OrderModel);
   //定义一个临时变量
   string tempName = string.Empty;
   //遍历DataTable中所有的数据行
   foreach (DataRow dr in dt.Rows)
   {
    OrderModel t = new OrderModel();
    // 获得此模型的公共属性
    PropertyInfo[] propertys = t.GetType().GetProperties();
    //遍历该对象的所有属性
    foreach (PropertyInfo pi in propertys)
    {
     tempName = pi.Name;//将属性名称赋值给临时变量
     //检查DataTable是否包含此列(列名==对象的属性名) 
     if (dt.Columns.Contains(tempName))
     {
      // 判断此属性是否有Setter
      if (!pi.CanWrite) continue;//该属性不可写,直接跳出
      //取值
      object value = dr[tempName];
      //如果非空,则赋给对象的属性
      if (value != DBNull.Value)
       pi.SetValue(t, value, null);
     }
    }
    //对象添加到泛型集合中
    ts.Add(t);
   }

   return ts;
  }

  #endregion

model页面的列中需要添加

  public ObservableCollection<OrderModel> ChildNodes { get; set; }
  public OrderModel()
  {
   ChildNodes = new ObservableCollection<OrderModel>();
  }

以上就是c# WPF中的TreeView使用详解的详细内容,更多关于c# WPF中的TreeView的资料请关注脚本之家其它相关文章!

相关文章

  • c#读取excel内容内容示例分享

    c#读取excel内容内容示例分享

    这篇文章主要介绍了c#读取excel内容内容示例,要求Excel需是.xls格式,需要的朋友可以参考下
    2014-03-03
  • C# 使用Word模板导出数据的实现代码

    C# 使用Word模板导出数据的实现代码

    最近接到个需求,使用word模板导出数据,怎么实现这个需求呢,今天小编通过实例代码给大家介绍C# 使用Word模板导出数据的方法,感兴趣的朋友一起看看吧
    2021-06-06
  • C#实现通过程序自动抓取远程Web网页信息的代码

    C#实现通过程序自动抓取远程Web网页信息的代码

    C#实现通过程序自动抓取远程Web网页信息的代码...
    2007-04-04
  • C#实现安全删除文件目录的方法

    C#实现安全删除文件目录的方法

    这篇文章主要介绍了C#实现安全删除文件目录的方法,涉及C#删除文件目录的相关技巧,非常具有实用价值,需要的朋友可以参考下
    2015-05-05
  • C#编程实现四舍五入、向上及下取整的方法

    C#编程实现四舍五入、向上及下取整的方法

    这篇文章主要介绍了C#编程实现四舍五入、向上及下取整的方法,涉及C#数学运算的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • C#实现简单的聊天窗体

    C#实现简单的聊天窗体

    这篇文章主要为大家详细介绍了C#实现简单的聊天窗体,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C#使用AutoMapper进行对象映射的示例代码

    C#使用AutoMapper进行对象映射的示例代码

    AutoMapper 是一个对象到对象映射的库,可以简化 DTO (Data Transfer Objects) 和实体类之间的转换,在大型应用程序中,通常需要将业务实体映射到视图模型或 DTO 中,本文将详细介绍如何在 C# 项目中使用 AutoMapper,包括安装、配置、以及示例代码
    2024-08-08
  • C#组件系列 你值得拥有的一款Excel处理神器Spire.XLS

    C#组件系列 你值得拥有的一款Excel处理神器Spire.XLS

    又一款Excel处理神器Spire.XLS,这篇文章主要为大家详细介绍了第三方组件Spire.XLS,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • C#实现Access通用访问类OleDbHelper完整实例

    C#实现Access通用访问类OleDbHelper完整实例

    这篇文章主要介绍了C#实现Access通用访问类OleDbHelper,结合完整实例形式分析了C#针对access数据库的连接、查询、遍历、分页显示等相关操作技巧,需要的朋友可以参考下
    2017-02-02
  • .Net Winform开发笔记(一)

    .Net Winform开发笔记(一)

    理解“Windows 窗体应用程序”项目中Program.cs文件中的main方法与传统C++Console控制台程序中的main方法的区别等等,感兴趣的朋友可以了解下
    2013-01-01

最新评论