DataTrigger.Value 属性

定义

获取或设置要与数据对象的属性值比较的值。

public:
 property System::Object ^ Value { System::Object ^ get(); void set(System::Object ^ value); };
[System.Windows.Localizability(System.Windows.LocalizationCategory.None, Readability=System.Windows.Readability.Unreadable)]
[System.Windows.Markup.DependsOn("Binding")]
public object Value { get; set; }
[<System.Windows.Localizability(System.Windows.LocalizationCategory.None, Readability=System.Windows.Readability.Unreadable)>]
[<System.Windows.Markup.DependsOn("Binding")>]
member this.Value : obj with get, set
Public Property Value As Object

属性值

默认值是 null。 请参见“异常”部分。

属性

例外

不支持表达式。 不支持绑定。

示例

在下面的示例中, ItemsSourceListBox 绑定到 Place 对象的 ObservableCollection<T>PlacesPlace 对象具有 属性 NameState

每个 ListBoxItemListBox 显示一个 Place 对象。 Style示例中的 应用于每个 ListBoxItem

指定 时,DataTrigger如果 Place 数据项的状态为“WA”,则相应 ListBoxItem 的前景设置为 Red。

<Window.Resources>
  <c:Places x:Key="PlacesData"/>

  <Style TargetType="ListBoxItem">
    <Style.Triggers>
      <DataTrigger Binding="{Binding Path=State}" Value="WA">
        <Setter Property="Foreground" Value="Red" />
      </DataTrigger>	
      <MultiDataTrigger>
        <MultiDataTrigger.Conditions>
          <Condition Binding="{Binding Path=Name}" Value="Portland" />
          <Condition Binding="{Binding Path=State}" Value="OR" />
        </MultiDataTrigger.Conditions>
        <Setter Property="Background" Value="Cyan" />
      </MultiDataTrigger>
    </Style.Triggers>
  </Style>

  <DataTemplate DataType="{x:Type c:Place}">
    <Canvas Width="160" Height="20">
      <TextBlock FontSize="12"
             Width="130" Canvas.Left="0" Text="{Binding Path=Name}"/>
      <TextBlock FontSize="12" Width="30"
                 Canvas.Left="130" Text="{Binding Path=State}"/>
    </Canvas>
  </DataTemplate>
</Window.Resources>

<StackPanel>
  <TextBlock FontSize="18" Margin="5" FontWeight="Bold"
    HorizontalAlignment="Center">Data Trigger Sample</TextBlock>
  <ListBox Width="180" HorizontalAlignment="Center" Background="Honeydew"
    ItemsSource="{Binding Source={StaticResource PlacesData}}"/>
</StackPanel>

下面的示例演示在 中定义的两 DataTriggerDataTemplateDataTemplate应用于 AuctionItem 数据对象, (此示例中未显示) ,这些对象具有 SpecialFeatures 属性。 有关完整示例,请参阅 数据绑定演示

指定第一 DataTrigger 个值,以便如果数据对象具有 Color 的 SpecialFeatures值,则该项目以具有海军标题的 DodgerBlue 背景显示。 如果数据对象的 SpecialFeatures 值为 Highlight,则第二 DataTrigger 个对象将处于活动状态,导致项目显示为带星形的橙色边框。

<DataTemplate.Triggers>
    <DataTrigger Binding="{Binding Path=SpecialFeatures}">
        <DataTrigger.Value>
            <src:SpecialFeatures>Color</src:SpecialFeatures>
        </DataTrigger.Value>
      <DataTrigger.Setters>
        <Setter Property="BorderBrush" Value="DodgerBlue" TargetName="border" />
        <Setter Property="Foreground" Value="Navy" TargetName="descriptionTitle" />
        <Setter Property="Foreground" Value="Navy" TargetName="currentPriceTitle" />
        <Setter Property="BorderThickness" Value="3" TargetName="border" />
        <Setter Property="Padding" Value="5" TargetName="border" />
      </DataTrigger.Setters>
    </DataTrigger>
    <DataTrigger Binding="{Binding Path=SpecialFeatures}">
        <DataTrigger.Value>
            <src:SpecialFeatures>Highlight</src:SpecialFeatures>
        </DataTrigger.Value>
        <Setter Property="BorderBrush" Value="Orange" TargetName="border" />
        <Setter Property="Foreground" Value="Navy" TargetName="descriptionTitle" />
        <Setter Property="Foreground" Value="Navy" TargetName="currentPriceTitle" />
        <Setter Property="Visibility" Value="Visible" TargetName="star" />
        <Setter Property="BorderThickness" Value="3" TargetName="border" />
        <Setter Property="Padding" Value="5" TargetName="border" />
    </DataTrigger>
</DataTemplate.Triggers>

注解

XAML 属性元素用法

<object>  
  <object.Value>  
    Value  
  </object.Value>  
</object>  

此值与 的 Binding 属性生成的属性值 DataTrigger进行比较。 该比较是一项引用相等性检查。 如果两个值相等,则应用关联的操作或资源库。

请注意,必须在 上DataTrigger指定 BindingValue 属性,数据触发器才能有意义。 如果未设置一个或两个属性,将引发异常。

适用于

另请参阅