1.先上效果node
將全部節點加入ComboBox數據源,在ComboBox中選擇時下方Treeview顯示該節點下的子節點。this
1.xaml文件,將如下代碼加入界面合適位置spa
1 <StackPanel> 2 <StackPanel Margin="10"> 3 <Label Content="選擇組節點:"></Label> 4 <ComboBox MaxDropDownHeight="100" Name="cmbGoup" DropDownClosed="cmbGoup_DropDownClosed"></ComboBox> 5 </StackPanel> 6 <StackPanel Margin ="10"> 7 <TreeView x:Name="tvGroup"> 8 <TreeView.ItemTemplate> 9 <HierarchicalDataTemplate ItemsSource="{Binding Nodes}"> 10 <StackPanel> 11 <TextBlock VerticalAlignment="Center" FontSize="14" Text="{Binding GroupName}" Margin="2,0,0,0"></TextBlock> 12 </StackPanel> 13 </HierarchicalDataTemplate> 14 </TreeView.ItemTemplate> 15 </TreeView> 16 </StackPanel> 17 </StackPanel>
2.後臺代碼code
a.用於綁定的節點類blog
1 public class Group 2 { 3 public Group() 4 { 5 this.Nodes = new List<Group>(); 6 this.ParentId = 0;//主節點的父id默認爲0 7 } 8 9 public List<Group> Nodes { get; set; } 10 public int ID { get; set; }//id 11 public int ParentId { get; set; }//parentID 12 public string GroupName { get; set; } 13 }
b.主界面類代碼遞歸
public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); #region 用於綁定的數據 List<Group> grpLst = new List<Group>(){ new Group(){ID=0,GroupName="Group", ParentId = -1}, new Group(){ID=1,GroupName="Group1",ParentId=0}, new Group(){ID=2,GroupName="Group2",ParentId=0}, new Group(){ID=3,GroupName="Group1_1",ParentId=1}, new Group(){ID=4,GroupName="Group1_2",ParentId=1}, new Group(){ID=5,GroupName="Group1_3",ParentId=1}, new Group(){ID=6,GroupName="Group1_4",ParentId=1}, new Group(){ID=7,GroupName="Group1_5",ParentId=1}, new Group(){ID=8,GroupName="Group2_1",ParentId=2}, new Group(){ID=9,GroupName="Group2_2",ParentId=2}, new Group(){ID=10,GroupName="Group2_3",ParentId=2}, new Group(){ID=11,GroupName="Group2_4",ParentId=2}, new Group(){ID=12,GroupName="Group1_1_1",ParentId=3}, new Group(){ID=13,GroupName="Group1_1_2",ParentId=3}, new Group(){ID=14,GroupName="Group1_2_1",ParentId=4}, new Group(){ID=15,GroupName="Group1_1_1_1",ParentId=12} }; #endregion this.cmbGoup.ItemsSource = grpLst;//comboBox數據源 this.cmbGoup.SelectedValuePath = "ID"; this.cmbGoup.DisplayMemberPath = "GroupName"; List<Group> lstGroup = getTreeData(-1, grpLst);//初始化時獲取父節點爲-1的數據 this.tvGroup.ItemsSource = lstGroup;//數據綁定 } /// <summary> /// 遞歸生成樹形數據 /// </summary> /// <param name="delst"></param> /// <returns></returns> public List<Group> getTreeData(int parentid, List<Group> nodes) { List<Group> mainNodes = nodes.Where(x => x.ParentId == parentid).ToList<Group>(); List<Group> otherNodes = nodes.Where(x => x.ParentId != parentid).ToList<Group>(); foreach (Group grp in mainNodes) { grp.Nodes = getTreeData(grp.ID, otherNodes); } return mainNodes; } /// <summary> /// 下拉框關閉事件 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void cmbGoup_DropDownClosed(object sender, EventArgs e) { if (this.cmbGoup.SelectedValue == null) { return; } int groupId = (int)this.cmbGoup.SelectedValue;//選中的組號 List<Group> lstGroup = getTreeData(groupId, (List<Group>)cmbGoup.ItemsSource); this.tvGroup.ItemsSource = lstGroup; } }