WPF中TreeView控件SelectedItemChanged方法的MVVM绑定

问题描述:左侧treeview控件中点击不同类别的节点时,右侧的页面会显示不同的权限。比如对于My Publications,拥有Modify和Delete两种权限,对于My Subscriptions,只拥有Unsubscribe的权限。

 

 

 

 我想到的办法是将权限绑定到TreeView控件的SelectedItemChanged方法,也就是说点击My Publications下面的子节点时,Modify和Delete两个Button控件是可见的,点击My Subscriptions下面的子节点时,Unsubscribe这个Button控件是可见的。

对于SelectedItemChanged使用MVVM绑定,使用到了System.Windows.Interactivity程序集。

<TreeView Name="treeview" Grid.Column="0" ItemsSource="{Binding Path=Resources}">
            <i:Interaction.Triggers>
                <i:EventTrigger EventName="SelectedItemChanged">
                    <i:InvokeCommandAction Command="{Binding Path=SelectedItemChangedCommand}" 
                                           CommandParameter="{Binding ElementName=treeview, Path=SelectedItem}"/>
                </i:EventTrigger>
            </i:Interaction.Triggers>
            <TreeView.ItemTemplate>
                <HierarchicalDataTemplate DataType="{x:Type local:TreeNode}" ItemsSource="{Binding Path=ChildNodes}">
                    <Label Content="{Binding Path=NodeName}"/>
                </HierarchicalDataTemplate>
            </TreeView.ItemTemplate>
        </TreeView>
XAML代码

注:需要引用System.Windows.Interactivity程序集

xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"

将SelectedItemChanged绑定到了SelectedItemChangedCommand方法,且传递的方法参数是treeview的SelectedItem。

注:为了让界面看起来更漂亮,我使用了MahApps.Metro,不知道为什么,在引用System.Windows.Interactivity程序集时,先引用的4.0版本,但是没有办法加载进来。后来改成了3.5版本,可以成功加载,但是其中没有Command属性,后又改成4.0版本,竟然可以成功加载了。

如果有更好的实现方法,请一定告诉我,谢谢~

2021.8.26补充,最近在做一个.net core wpf项目,用不了System.Windows.Interactivity程序集,需要安装Microsoft.Xaml.Behaviors.Wpf包,然后引用xmlns:i="http://schemas.microsoft.com/xaml/behaviors",其他都不变。

2021.12.14补充,关于TreeView控件的demo:

WPF中常用控件(TreeView, ComboBox, DataGrid, ListView)使用MVVM模式绑定的demo - 南风小斯 - 博客园 (cnblogs.com)

posted @ 2020-06-24 11:04  南风小斯  阅读(3685)  评论(6编辑  收藏  举报