根据Avalonia ItemsControl中的ViewModel类型选择数据模板



内部有ItemsControl的UserControl,需要根据items集合元素类型显示具有不同DataTemplate的项。

以下基于此答案创建的TemplateSelector和XAML(根据Avalonia中的DataContext属性选择DataTemplate(

<ItemsControl Items="{Binding Items}">
<ItemsControl.DataTemplates>
<views:ItemsTemplateSelector>
<DataTemplate x:Key="{x:Type itemViewModels:Item1ViewModel}">
<itemsViews:Item1View/>
</DataTemplate>
<DataTemplate x:Key="{x:Type itemViewModels:Item2ViewModel}">
<itemsViews:Item2View/>
</DataTemplate>
</views:ItemsTemplateSelector>
</ItemsControl.DataTemplates>
</ItemsControl>
public ItemsViewModel()
{
this.Items = new ObservableCollection<IItemViewModel>();
this.Items.Add(new Item1ViewModel("Item1"));
this.Items.Add(new Item2ViewModel("Item2"));
}
public ObservableCollection<IitemViewModel> Items { get; }
public class ItemsTemplateSelector : IDataTemplate
{
public bool SupportsRecycling => false;
[Content]
public Dictionary<Type, IDataTemplate> Templates { get; } = new Dictionary<Type, IDataTemplate>();
public IControl Build(object data)
{
var type = data.GetType();
var template = this.Templates[type];
var control = template.Build(data);
return control;
}
public bool Match(object data)
{
return data is IItemViewModel;
}
}
public interface IItemViewModel
{
string Name { get; }
}
public class Item1ViewModel : IItemViewModel
{
public Item1ViewModel (string name)
{
this.Name = name;
}
public string Name { get; }
}
<UserControl
xmlns="https://github.com/avaloniaui"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
x:Class="Desktop.Views.Items.Item1View">
<TextBlock Text="{Binding Name}"/>
</UserControl>

运行时出现异常:

Avaloni.Markup.Xaml.XamlLoadException:"找不到Desktop.Views.Items.Item1View的预编译Xaml,请确保指定x:Class并将Xaml文件包含为AvaloniResource">

如果在ItemsControl而不是<itemsViews:Item1View/>中指定<TextBlock Text="{Binding Name}"/>,则一切正常。但我想将每个项的标记拆分为一个单独的XAML文件,该文件具有单独的ViewModel。项目可能完全不同。

是否可以解决此问题,以便ItemsControl根据ViewModel类型选择DataTemplate?

为了解决这个问题,我手动编辑了项目文件*.csproj添加了AvaloniResource元素

<AvaloniaResource Include="..DesktopViewsItems*.xaml">
<SubType>Designer</SubType>
</AvaloniaResource>

最新更新