[英]TemplateSelector for UWP NavigationView
如何正確使用MenuItemTemplateSelector進行UWP NavigationView? 我從互聯網上查了一些樣本並嘗試了它們(下面的代碼)。 但它不起作用,因為它應該只打印類名。 目前我在Windows版本1809上運行。我已經嘗試在listView中使用相同的模板,它可以工作,所以我想知道是否可能在NavigationView中有錯誤,或者我錯過了什么? 提前致謝 :)
這就是我的代碼:
創建模板選擇器:
public class NavigationItemTemplateSelector : DataTemplateSelector
{
public DataTemplate DriveTemplate { get; set; }
public DataTemplate PathTemplate { get; set; }
protected override DataTemplate SelectTemplateCore(object item, DependencyObject container)
{
return SelectTemplateCore(item);
}
protected override DataTemplate SelectTemplateCore(object item)
{
if (item is Drive) return DriveTemplate;
if (item is FileSystemElement) return PathTemplate;
return base.SelectTemplateCore(item);
}
}
在您的頁面資源中添加這樣的內容:
<Page.Resources>
<DataTemplate x:Key="FileSystemDataTemplate" x:DataType="entities:FileSystemElement">
<StackPanel>
<TextBlock Text="{x:Bind Name}" />
</StackPanel>
</DataTemplate>
<DataTemplate x:Key="DriveDataTemplate" x:DataType="entities:Drive">
<StackPanel>
<SymbolIcon Symbol="{x:Bind Icon}" />
<TextBlock Text="{x:Bind Name}" />
</StackPanel>
</DataTemplate>
<entities:NavigationItemTemplateSelector x:Key="NVMenuItemsSelector"
DriveTemplate="{StaticResource DriveDataTemplate}"
PathTemplate="{StaticResource FileSystemDataTemplate}">
</entities:NavigationItemTemplateSelector>
</Page.Resources>
告訴NavigationView它應該使用這個TemplateSelector
<NavigationView MenuItemsSource="{x:Bind ViewModel.NavigationItems, Mode=OneWay}"
MenuItemTemplateSelector="{StaticResource NVMenuItemsSelector}">
看看這個鏈接。
無法在NavigationView MenuItemTemplate中綁定Icon屬性
我相信在ContentPresenter中包裝StackPanels可以解決您的問題。
<DataTemplate x:Key="FileSystemDataTemplate" x:DataType="entities:FileSystemElement">
<ContentPresenter>
<StackPanel>
<TextBlock Text="{x:Bind Name}" />
</StackPanel>
</ContentPresenter>
</DataTemplate>
<DataTemplate x:Key="DriveDataTemplate" x:DataType="entities:Drive">
<ContentPresenter>
<StackPanel>
<SymbolIcon Symbol="{x:Bind Icon}" />
<TextBlock Text="{x:Bind Name}" />
</StackPanel>
</ContentPresenter>
</DataTemplate>
在查看上面的鏈接后,我決定在我的模板中放置一個NavigationViewItem
<DataTemplate x:Key="DriveDataTemplate" x:DataType="entities:Drive">
<NavigationViewItem Icon="{x:Bind SymbolIcon}">
<StackPanel Orientation="Horizontal">
<TextBlock Text="{x:Bind Name}" />
</StackPanel>
</NavigationViewItem>
</DataTemplate>
它有效。 好像你必須將NavigationViewItem作為第一個孩子。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.