DataTrigger.Value 属性
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
获取或设置要与数据对象的属性值比较的值。
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
。 请参见“异常”部分。
- 属性
例外
不支持表达式。 不支持绑定。
示例
在下面的示例中, ItemsSource 的 ListBox 绑定到 Place 对象的 ObservableCollection<T>Places 。 Place 对象具有 属性 Name 和 State。
每个 ListBoxItem 都 ListBox 显示一个 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>
下面的示例演示在 中定义的两 DataTrigger个 DataTemplate。 DataTemplate应用于 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指定 Binding 和 Value 属性,数据触发器才能有意义。 如果未设置一个或两个属性,将引发异常。