16

我需要将Visibilitya绑定DataGridTemplateColumn到外部的属性DataGrid.ItemsSource,因为我需要将所有行中的这一列绑定到内部的一个属性ViewModel,但据我所知,您可以将其绑定到内部的某个属性,ItemsSource或者您应该使用ElementStyleEditingElementStyle 我已经尝试过这段代码:

 <DataGridTemplateColumn Header="post" 
                      Visibility="{Binding DataContext.ProjectPostVisibility
                    , RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=MvvmCommonControl:DataGrid}}"/>

而且我确定我的绑定是正确的,因为当我绑定DataGridCell.Visibility以下内容时它可以正常工作:

<DataGridTemplateColumn Header="post">
    <DataGridTemplateColumn.CellStyle>
                        <Style TargetType="DataGridCell">
                            <Setter Property="Visibility" Value="{Binding DataContext.ProjectPostVisibility,RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=MvvmCommonControl:DataGrid}}"/>
                        </Style>
                    </DataGridTemplateColumn.CellStyle>
</DataGridTemplateColumn >
4

3 回答 3

26

您的绑定是正确的,但它不能DataGridTemplateColumn直接使用,因为它不在可视树中。所以它不是继承的DataContext

您需要绑定DataGridTemplateColumn后面的代码。这是一个演示,展示了一种方法。

于 2013-03-09T12:41:42.367 回答
4

在 DataGridTemplateColumn.CellStyle 中添加此设置器并完成:

   <Setter Property="Visibility" Value="{Binding DataContext.isVisible, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"/>

如果您需要更多帮助,请查看下面的示例。我希望删除按钮在项目级别不可见。首先,您必须确保您的视图模型中有 isVisible 属性:

  private System.Windows.Visibility _isVisible;
    public System.Windows.Visibility isVisible
    {
        get { return _isVisible; }
        set
        {
            if (_isVisible != value)
            {
                _isVisible = value;
                OnPropertyChanged("isVisible");
            }
        }
    }

然后:

  if (isProj == false)
            this.model.isVisible = Visibility.Visible;
        else
            this.model.isVisible = Visibility.Collapsed;

XAML:

<DataGridTemplateColumn  >
       <DataGridTemplateColumn.CellTemplate >
            <DataTemplate >
               <Button x:Name="btnRemove" Content="X">
                 <Button.Style>
                    <Style TargetType="{x:Type Button}">
                         <Setter Property="FontWeight" Value="ExtraBold" />
                         <Setter Property="FontSize" Value="50" />
                     </Style>
                 </Button.Style>
            </Button>
         </DataTemplate>
   </DataGridTemplateColumn.CellTemplate>
   <DataGridTemplateColumn.CellStyle>
        <Style TargetType="{x:Type DataGridCell}">
               <Setter Property="Background"  Value="Red"/>
               <Setter Property="Visibility" Value="{Binding DataContext.isVisible, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"/>
        </Style>
   </DataGridTemplateColumn.CellStyle>

于 2017-07-12T16:10:05.403 回答
4

正如其他答案中提到的那样,该列不是视觉/逻辑树的一部分,也不是从FrameworkElement它没有的含义继承而来的DataContext。这就是为什么您的绑定不起作用的原因。

FrameworkElement但是,您可以在您正在寻找的级别添加一个虚拟(折叠)DataContext(以您的示例为例,它将在 DataGrid 的级别),折叠它并将其用作您的绑定源x:Reference标记扩展。

这是一个例子:

<FrameworkElement x:Name="Proxy" Visibility="Collapsed"/>
<DataGrid>
    <DataGrid.Columns>
        <DataGridTemplateColumn Header="post" 
            Visibility="{Binding DataContext.ProjectPostVisibility, Source={x:Reference Name=Proxy}}"/>
    </DataGrid.Columns>
</DataGrid>
于 2021-04-01T14:11:09.440 回答