NavigationViewItem.MenuItemsSource 속성
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
NavigationViewItem의 자식을 생성하는 데 사용되는 개체 원본을 가져오거나 설정합니다.
이 설명서는 UWP용 WinUI 2에 적용됩니다(Windows 앱 SDKWinUI의 경우 Windows 앱 SDK 네임스페이스 참조).
public:
property Platform::Object ^ MenuItemsSource { Platform::Object ^ get(); void set(Platform::Object ^ value); };
/// [Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)]
/// [get: Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)]
/// [set: Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)]
IInspectable MenuItemsSource();
void MenuItemsSource(IInspectable value);
[Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)]
public object MenuItemsSource { [Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)] get; [Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallback(enable=true)] set; }
Public Property MenuItemsSource As Object
<NavigationViewItem MenuItemsSource="{x:Bind Object}" .../>
속성 값
NavigationViewItem의 자식을 포함하는 개체 원본입니다.
- 특성
-
Microsoft.UI.Xaml.CustomAttributes.MUXPropertyChangedCallbackAttribute
예제
다음은 항목 템플릿을 NavigationViewMenuItem으로 정의하고 콘텐츠가 메뉴 항목의 레이블로 설정되고 MenuItemsSource 속성이 계층의 다음 수준에 바인딩된 계층 구조를 추가하는 예제입니다.
<DataTemplate x:Key="NavigationViewMenuItem" x:DataType="local:Category">
<muxc:NavigationViewItem Content="{x:Bind Name}" MenuItemsSource="{x:Bind Children}"/>
</DataTemplate>
<muxc:NavigationView x:Name="navview"
MenuItemsSource="{x:Bind categories, Mode=OneWay}"
MenuItemTemplate="{StaticResource NavigationViewMenuItem}"
ItemInvoked="{x:Bind OnItemInvoked}"
Expanding="OnItemExpanding"
Collapsed="OnItemCollapsed"
PaneDisplayMode="Left">
<StackPanel Margin="10,10,0,0">
<TextBlock Margin="0,10,0,0" x:Name="ExpandingItemLabel" Text="Last Expanding: N/A"/>
<TextBlock x:Name="CollapsedItemLabel" Text="Last Collapsed: N/A"/>
</StackPanel>
</muxc:NavigationView>
public class Category
{
public String Name { get; set; }
public String Icon { get; set; }
public ObservableCollection<Category> Children { get; set; }
}
public sealed partial class HierarchicalNavigationViewDataBinding : Page
{
public HierarchicalNavigationViewDataBinding()
{
this.InitializeComponent();
}
public ObservableCollection<Category> Categories = new ObservableCollection<Category>()
{
new Category(){
Name = "Menu Item 1",
Icon = "Icon",
Children = new ObservableCollection<Category>() {
new Category(){
Name = "Menu Item 2",
Icon = "Icon",
Children = new ObservableCollection<Category>() {
new Category() {
Name = "Menu Item 2",
Icon = "Icon",
Children = new ObservableCollection<Category>() {
new Category() { Name = "Menu Item 3", Icon = "Icon" },
new Category() { Name = "Menu Item 4", Icon = "Icon" }
}
}
}
}
}
},
new Category(){
Name = "Menu Item 5",
Icon = "Icon",
Children = new ObservableCollection<Category>() {
new Category(){
Name = "Menu Item 6",
Icon = "Icon",
Children = new ObservableCollection<Category>() {
new Category() { Name = "Menu Item 7", Icon = "Icon" },
new Category() { Name = "Menu Item 8", Icon = "Icon" }
}
}
}
},
new Category(){ Name = "Menu Item 9", Icon = "Icon" }
};
private void OnItemInvoked(object sender, NavigationViewItemInvokedEventArgs e)
{
var clickedItem = e.InvokedItem;
var clickedItemContainer = e.InvokedItemContainer;
}
private void OnItemExpanding(object sender, NavigationViewItemExpandingEventArgs e)
{
var nvib = e.ExpandingItemContainer;
var name = "Last Expanding: " + nvib.Content.ToString();
ExpandingItemLabel.Text = name;
}
private void OnItemCollapsed(object sender, NavigationViewItemCollapsedEventArgs e)
{
var nvib = e.CollapsedItemContainer;
var name = "Last Collapsed: " + nvib.Content;
CollapsedItemLabel.Text = name;
}
}
public sealed class NavigationViewItemExpandingEventArgs
{
public NavigationViewItemExpandingEventArgs() {}
public object ExpandingItem { get; }
public NavigationViewItemBase ExpandedItemContainer { get; }
public bool IsSettingsInvoked { get; }
public NavigationTransitionInfo RecommendedNavigationTransitionInfo { get; }
}
public sealed class NavigationViewItemCollapsedEventArgs
{
public NavigationViewItemCollapsedEventArgs() {}
public object CollapsedItem { get; }
public NavigationViewItemBase CollapsedItemContainer { get; }
public bool IsSettingsInvoked { get; }
public NavigationTransitionInfo RecommendedNavigationTransitionInfo { get; }
}