祖先绑定仅在ListView中起作用一次

时间:2018-12-11 16:57:20

标签: c# wpf xaml binding ancestor

我的窗口中有样式。资源:

<Style x:Key="Header" TargetType="GridViewColumnHeader">
        <Setter Property="Content">
            <Setter.Value>
                <StackPanel Orientation="Horizontal">
                    <Label Width="80" HorizontalContentAlignment="Center" Content="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=GridViewColumnHeader, AncestorLevel=1}, Path=Tag}" />
                    <StackPanel Orientation="Vertical">
                        <Polygon Name="P_up" Points="0,5 10,5, 5,0" Stroke="Black" Fill="Black" Margin="3" Visibility="Visible"/>
                        <Polygon Name="P_down" Points="0,0 10,0, 5,5" Stroke="Black" Fill="Black" Margin="3" Visibility="Hidden"/>
                    </StackPanel>
                </StackPanel>
            </Setter.Value> 
        </Setter>
        <EventSetter Event="Click" Handler="Header_Click"/>
    </Style>

当我将样式设置为 ListView (GridViewColumnHeader)时,如下所示:

<ListView Height="300" x:Name="lv" ItemsSource="{Binding PLCs}">
        <ListView.View>
            <GridView>
                <GridViewColumn Width="120">
                    <GridViewColumnHeader Name="myNewText" Tag="test" Style="{StaticResource Header}"/>
                </GridViewColumn>
                <GridViewColumn Width="120">
                    <GridViewColumnHeader Name="myNewText2" Tag="test2"  Style="{StaticResource Header}"/>
                </GridViewColumn>
                <GridViewColumn Width="120">
                    <GridViewColumnHeader Tag="test32"  Style="{StaticResource Header}"/>
                </GridViewColumn>
            </GridView>
        </ListView.View>
    </ListView>        

与祖先 Tag 的绑定有效,并且显示 Polygon ,但仅对于 GridViewColumns 中的最后一个,第一个两个都保持空白。谁能告诉我我在做什么错?由于所有三列的代码都相同,因此我认为这将为我提供全部三列相同的结果。我猜想标签 Content 绑定或 Style TargetType 是不正确的。

感谢您的帮助。

1 个答案:

答案 0 :(得分:3)

您应该使用ContentTemplate属性:

<Setter Property="ContentTemplate">
    <Setter.Value>
         <DataTemplate>
          <! -- ...place your stack panel here -->
         </DataTemplate>
    </Setter.Value>
</Setter>

这样做,您为每个列标题定义了一个模板。该模板将分别实例化每个列标题的内容。

如果使用Content属性,则将与内容相同的堆栈面板设置为所有列标题。这行不通-只有最后一个赢。堆栈面板的父项将自动设置为最后一个标题。就像:

header1.Content = your_stack_panel;
your_stack_panel.Parent = header1;

header2.Content = your_stack_panel;
your_stack_panel.Parent = header2;

header3.Content = your_stack_panel;
your_stack_panel.Parent = header3;