绑定鼠标的问题通过M-V-MV设计模式双击
本文关键字:M-V-MV 设计模式 双击 鼠标 问题 绑定 | 更新日期: 2023-09-27 18:28:47
我在.xaml文件中有以下代码片段:
<TreeView MouseDoubleClick="TreeView_MouseDoubleClick" ItemsSource="{Binding MyList}">
<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<Setter Property="IsExpanded" Value="{Binding IsExpanded, Mode=TwoWay}" />
<Setter Property="IsSelected" Value="{Binding IsSelected, Mode=TwoWay}" />
<Setter Property="FontWeight" Value="Normal" />
<Style.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="FontWeight" Value="Bold" />
</Trigger>
</Style.Triggers>
</Style>
</TreeView.ItemContainerStyle>
正如你所看到的,当你在树视图中的一个项目上"鼠标双击"时,它会执行后面代码中的代码。。。即
private void TreeView_MouseDoubleClick(object sender, System.Windows.Input.MouseButtonEventArgs e)
{
try
{
MessageBox.Show(((TreeViewWithViewModelDemo.LoadOnDemand.HtmlFileViewModel)(((System.Windows.Controls.TreeView)(sender)).SelectedValue)).HtmlFileName);
}
catch
{
}
}
我正在尝试遵循模型视图ViewModel设计模式,并希望将此MouseDoubleClick事件的实现从视图移到ViewModel中。
我知道,如果我使用的是一个命令,我会使用{Binding command="Select"}(或实现ICommand接口的类似命令),但我似乎找不到这个特定问题的语法,因为它不是一个命令按钮。
有人能帮我吗?
感谢
这里有一个使用Blend交互触发器的解决方案。
<Page.DataContext>
<Samples:TreeViewDblClickViewModel/>
</Page.DataContext>
<Grid>
<TreeView ItemsSource="{Binding Items}">
<TreeView.ItemTemplate>
<DataTemplate>
<ContentControl>
<i:Interaction.Triggers>
<i:EventTrigger EventName="MouseDoubleClick">
<i:InvokeCommandAction Command="{Binding DoubleClickCommand}"/>
</i:EventTrigger>
</i:Interaction.Triggers>
<TextBlock Text="{Binding Name}" Background="AliceBlue" Margin="2"/>
</ContentControl>
</DataTemplate>
</TreeView.ItemTemplate>
</TreeView>
</Grid>
查看型号
public class TreeViewDblClickViewModel
{
public TreeViewDblClickViewModel()
{
Items = new List<TreeViewDblClickItem>
{
new TreeViewDblClickItem{ Name = "One"},
new TreeViewDblClickItem{ Name = "Two"},
new TreeViewDblClickItem{ Name = "Thee"},
new TreeViewDblClickItem{ Name = "Four"},
};
}
public IList<TreeViewDblClickItem> Items { get; private set; }
}
public class TreeViewDblClickItem
{
public TreeViewDblClickItem()
{
DoubleClickCommand = new ActionCommand(DoubleClick);
}
public string Name { get; set; }
private void DoubleClick()
{
Debug.WriteLine("Double click");
}
public ICommand DoubleClickCommand { get; private set; }
}
使用MVVM并不意味着代码隐藏文件中不能有任何代码。它只是意味着将所有相关联的逻辑移动到视图模型中。您可以在视图模型上实现必要的双击方法,并从代码后面调用它,如下所示:
_viewModel.MouseDoubleClickOnTree();
此外,我建议大家看看这个主题:MVVM C#WPF绑定鼠标双击
我建议您开始使用像Prism等MVVM模式的库。它解决了一般问题,您可以把时间花在做业务上,而不是重新发明轮子。
实际上,几天前我就这个话题向某人发布了一个答案。以下是我发布的
显然,这是针对列表视图项,而不是树视图项,但它仍然可以工作,只需进行一些小的更改。