如何从网格视图列的单元格模板绑定到该列的属性



我想解决的一般问题是,一个复选框只有一个数据模板,然后我可以将其用于列表视图中的许多不同列(使用网格视图)。在所有的例子中,我都看到为每个绑定创建了一个单独的模板,这对我来说似乎有些过头了

我一直试图通过创建一个gridviewcolumn将设置的附加属性来实现这一点。然后,我可以简单地为一个复选框提供一个数据模板,该复选框绑定到附加的属性。

我遇到的问题实际上是将复选框源设置为gridview列。

这是xaml:

<DataTemplate x:Key="CheckBoxTemplate">
    <CheckBox IsChecked="{Binding Path=(ap:AttachedProperties.IsChecked),
        RelativeSource={RelativeSource AncestorType={x:Type GridViewColumn}}}" />
</DataTemplate>
<GridView x:Key="MyGridView">
    <GridViewColumn Header="CheckBox" CellTemplate="{StaticResource CheckBoxTemplate}" ap:AttachedProperties.IsChecked="{Binding Path=SomeValue}" />
</GridView>

p.S.Attached属性运行良好,我已将其直接附加到复选框,并使用相对源自绑定并获得值,但当我尝试将其绑定到GridViewColumn上时,我没有得到任何好处,事实上,我也无法绑定到GridView Column上的Header

p.p.S我也尝试过其他绑定源表达式(只是看起来不合适)

编辑:在发布这篇文章后,我立刻意识到所有行都存在GridViewColumn,所以这可能就是为什么它不起作用的原因?!

我现在已经睡过了,意识到以这种方式做事是行不通的(因为GridViewColumn只能保存第一行的值,而不是我需要的每一行的值)-然而,我仍然认为绑定到GridViewColumn是可能的?

下面是一个仅xaml的示例来显示行为:

<Window x:Class="WpfApplication3.MainWindow"
       xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
       xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
       Title="MainWindow"
       Width="525"
       Height="350">
   <Grid>
       <ListView Name="listView1"
                 Width="479"
                 Height="287"
                 Margin="12,12,0,0"
                 HorizontalAlignment="Left"
                 VerticalAlignment="Top">
           <ListView.View>
               <GridView>
                   <GridViewColumn Header="A Header">
                       <GridViewColumn.CellTemplate>
                           <DataTemplate>
                               <StackPanel>
                                   <TextBlock Text="{Binding Path=Header, RelativeSource={RelativeSource AncestorType={x:Type GridViewColumn}}}" />
                                   <TextBlock Text="Visible row" />
                               </StackPanel>
                           </DataTemplate>
                       </GridViewColumn.CellTemplate>
                   </GridViewColumn>
               </GridView>
           </ListView.View>
           <ListViewItem />
           <ListViewItem />
       </ListView>
   </Grid>
</Window>

在这样的场景下,我希望在每个"可见行"文本上方看到"页眉"

我检查了snoop,这就是为什么它不起作用的原因,因为GridColumnHeader不在GridRows所在的VisualTree中。我的解决方案是使用ElementName并将其绑定到Header属性。相当简单,更干净可读。

    <ListView Name="listView1"
             Width="479"
             Height="287"
             Margin="12,12,0,0"
             HorizontalAlignment="Left"
             VerticalAlignment="Top">
        <ListView.View>
            <GridView>
                <GridViewColumn Header="A Header" x:Name="HeaderOne">
                    <GridViewColumn.CellTemplate>
                        <DataTemplate>
                            <StackPanel>
                                <TextBlock Text="{Binding ElementName=HeaderOne,Path=Header}" />
                                <TextBlock Text="Visible row" />
                            </StackPanel>
                        </DataTemplate>
                    </GridViewColumn.CellTemplate>
                </GridViewColumn>
            </GridView>
        </ListView.View>
        <ListViewItem />
        <ListViewItem />
    </ListView>

我试图绑定到GridViewColumn的问题似乎有两个方面:

  • 首先,GridViewColumn只能提供一个结果值(可能是itemsource中的第一个项),而不是每行提供一个值。

  • 其次,GridViewColumn似乎不存在于可视化树中,因此无法绑定到.

进一步的研究表明,要绑定到GridViewColumn的属性,可以使用以下语法:

<TextBlock Text="{Binding Path=View.Columns[0].Header, RelativeSource={RelativeSource AncestorType={x:Type ListView}}}" />

从MSDN获得:将参数传递到GridViewColumn 中指定的CellTemplate

最新更新