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 物件的 Places ObservableCollection<T> 。 放置 物件具有 屬性 Name 和 State。
每個 ListBoxItem 都會顯示 Place ListBox 物件。 Style範例中的 會套用至每個 ListBoxItem 。
DataTrigger會指定 ,如此一來,如果 Place 資料 項的狀態為「WA」,則對應的 ListBoxItem 前景會設定為紅色。
<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會套用至有 SpecialFeatures 屬性的 (本範例中未顯示之) 的 的 AuctionItem 資料物件。 如需完整範例,請參閱 資料系結示範 。
第一個 DataTrigger 是指定,如果資料物件具有 Color 的 SpecialFeatures 值,則 專案會顯示為 DodgerBlue 背景,其中包含一個具有一般標題的 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>
這個值會與 的 屬性 DataTrigger 所產生的 Binding 屬性值進行比較。 這個比較是參考相等檢查。 如果兩個值相等,則會套用相關聯的動作或 setter。
請注意,您必須在 上 DataTrigger 指定 Binding 和 Value 屬性,資料觸發程式才能有意義。 如果未設定一或兩個屬性,則會擲回例外狀況。