在WPF中,可以使用TreeView控件来显示节点,并根据搜索条件来显示相应的节点。
首先,你需要在WPF窗口中添加一个TreeView控件,并定义节点的数据模型。例如,假设你的数据模型是一个简单的树形结构:
public class Node { public string Name { get; set; } public ObservableCollectionChildren { get; set; } }
然后,在窗口的代码文件中,你可以定义一个根节点的集合,并将其作为TreeView的数据源:
public partial class MainWindow : Window { public ObservableCollectionNodes { get; set; } public MainWindow() { InitializeComponent(); Nodes = new ObservableCollection { new Node { Name = "Node 1", Children = new ObservableCollection { new Node { Name = "Node 1.1" }, new Node { Name = "Node 1.2" } } }, new Node { Name = "Node 2", Children = new ObservableCollection { new Node { Name = "Node 2.1" }, new Node { Name = "Node 2.2" } } } }; treeView.ItemsSource = Nodes; } }
接下来,在搜索按钮的点击事件中,你可以根据搜索条件来过滤节点,并重新设置TreeView的数据源:
private void SearchButton_Click(object sender, RoutedEventArgs e)
{
string searchKeyword = searchTextBox.Text.Trim();
if (string.IsNullOrWhiteSpace(searchKeyword))
{
treeView.ItemsSource = Nodes;
}
else
{
var filteredNodes = new ObservableCollection();
FilterNodes(Nodes, filteredNodes, searchKeyword);
treeView.ItemsSource = filteredNodes;
}
}
private void FilterNodes(IEnumerable nodes, ObservableCollection filteredNodes, string searchKeyword)
{
foreach (var node in nodes)
{
if (node.Name.Contains(searchKeyword))
{
filteredNodes.Add(node);
}
if (node.Children != null)
{
FilterNodes(node.Children, filteredNodes, searchKeyword);
}
}
}
以上代码中的FilterNodes方法使用递归遍历所有节点,并将匹配搜索条件的节点添加到filteredNodes集合中。
最后,在XAML文件中,你需要为搜索按钮的点击事件添加事件处理程序:
这样,当你输入搜索条件并点击搜索按钮时,TreeView将显示相应的节点。