如何在Pivot中查找子项并将其显示为false

问题描述 投票:0回答:1

我有一个带有子项的数据透视表作为网格。我试图找到枢轴选择更改的网格。我的代码是这样的

  <Pivot x:Name="mainContentPivot"  SelectionChanged="mainContentPivot_SelectionChanged" ItemsSource="{x:Bind viewModel.headerElement, Mode=OneWay}" >

        <Pivot.HeaderTemplate>
            <DataTemplate x:DataType="models:HeaderUIModel">
                <TextBlock Text="{Binding Name, Mode=OneWay}"/>
            </DataTemplate>
        </Pivot.HeaderTemplate>
        <Pivot.ItemTemplate>
            <DataTemplate>
                <Grid Name="grd">

                </Grid>
            </DataTemplate>

        </Pivot.ItemTemplate>
    </Pivot>


   private void mainContentPivot_SelectionChanged(object sender, SelectionChangedEventArgs e)
    {
        PivotItem item = (sender as Pivot).ContainerFromItem((sender as Pivot).SelectedItem) as PivotItem;
        var gridView = FindElementInVisualTree<GridView>(item);
    }

    private T FindElementInVisualTree<T>(DependencyObject parentElement) where T : DependencyObject
    {
        var count = VisualTreeHelper.GetChildrenCount(parentElement);
        if (count == 0) return null;

        for (int i = 0; i < count; i++)
        {
            var child = VisualTreeHelper.GetChild(parentElement, i);
            if (child != null && child is T)
                return (T)child;
            else
            {
                var result = FindElementInVisualTree<T>(child);
                if (result != null)
                    return result;
            }
        }
        return null;
    }

在选定项目更改时,我总是将gridView设为NULL。我在这里错了吗?

c# xaml uwp uno-platform
1个回答
0
投票
在您的Xaml中,您有一个Grid,而在您的C#代码中,您有一个GridView,这是问题所在吗?尽管名称相似,但它们是完全不同的控件。
© www.soinside.com 2019 - 2024. All rights reserved.