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 바인딩 Places된 개체입니다 ObservableCollection<T>Place .
Place 개체에는 속성 Name 과 State.
각 ListBoxItem 개체가 ListBoxPlace 표시됩니다.
Style 이 예제에서는 각각ListBoxItem에 적용됩니다.
DataTrigger 데이터 항목의 Place 전경이 "WA"인 경우 State 해당 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개의 s를 DataTemplate보여 있습니다. 속성이 DataTemplate 있는 SpecialFeatures데이터 개체(이 예제에는 표시되지 않음)에 적용 AuctionItem 됩니다.
첫 번째는 DataTrigger 데이터 개체 SpecialFeatures 의 Color값이 있는 경우 항목이 Navy 제목이 있는 DodgerBlue 배경과 함께 표시되도록 지정됩니다. 데이터 개체의 Highlight값이 SpecialFeatures 있으면 두 번째 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. 비교는 참조 같음 검사입니다. 두 값이 같으면 연결된 작업 또는 setter가 적용됩니다.
메모
데이터 트리거의 Binding 의미 있는 속성과 Value 속성을 DataTrigger 모두 지정해야 합니다. 하나 또는 두 속성이 모두 설정되지 않은 경우 예외가 throw됩니다.