2012-07-17 52 views
0

我希望ComboBox出現錯誤時,我的ComboBox旁邊的標籤文本變爲紅色,但是我目前如何設置Label的文本顏色只更新控制器的初始負載。如何在ComboBox中的選擇發生變化時驗證標籤?還是有另一種方式來更新標籤的風格?基於另一個控件驗證的樣式標籤

我有以下XAML:

<Style x:Key="labelStyle" TargetType="Label"> 
    <Setter Property="HorizontalContentAlignment" Value="Left" /> 
    <Setter Property="VerticalContentAlignment" Value="Center" /> 
    <Setter Property="Validation.ErrorTemplate"> 
     <Setter.Value> 
      <ControlTemplate> 
       <AdornedElementPlaceholder> 
        <Border BorderBrush="Transparent" BorderThickness="0" /> 
       </AdornedElementPlaceholder> 
      </ControlTemplate> 
     </Setter.Value> 
    </Setter> 

    <Style.Triggers> 
     <Trigger Property="Validation.HasError" Value="true"> 
      <Setter Property="Background" Value="White"/> 
      <Setter Property="Foreground" Value="Red"/> 
     </Trigger> 
    </Style.Triggers> 
</Style> 

<Label Style="{StaticResource labelStyle}" Content="{Binding Path=Label, ValidatesOnDataErrors=True}" /> 

<ComboBox ItemsSource="{Binding Path=ItemList}" SelectedItem="{Binding Path=SelectedItem, ValidatesOnDataErrors=True}"/> 

然後在代碼:

public string this[string propertyName] 
{ 
    get 
    { 
     if (propertyName == "Label") 
     { 
      if (this.IsRequired && !DelayValidation && SelectedItem == "") 
       return Label + " required"; 
     } 

     return null; 
    } 
} 

回答

1

隨着你是怎麼做到的,你就還需要提高財產上的「標籤」性質,只要改變您的'SelectedItem'屬性發生變化。

你可以做到這一點,而不必在你的模型/視圖模型(或者你綁定的任何東西)上使用xaml解決方案。如果你有一個像一個組合框:

<ComboBox Name="comb" ItemsSource="{Binding Strings}" SelectedValue="{Binding Stringy,ValidatesOnDataErrors=True}" /> 

你可以做一個標籤,如:

<Label Content="Select a string"> 
    <Label.Style> 
     <Style TargetType="Label"> 
      <Style.Triggers> 
       <DataTrigger Binding="{Binding ElementName=comb,Path=(Validation.HasError)}" Value="True"> 
        <Setter Property="Foreground" Value="Red" /> 
       </DataTrigger> 
      </Style.Triggers> 
     </Style> 
    </Label.Style> 
</Label> 

或者,如果你想這對多個控件(或者,如果你不希望有這種風格/在標籤的顯式的觸發),你可以做出這樣的附加屬性/行爲:

public class LabelValidationHelper 
{ 
    public static FrameworkElement GetDetailControl(DependencyObject obj) 
    { 
     return (FrameworkElement)obj.GetValue(DetailControlProperty); 
    } 

    public static void SetDetailControl(DependencyObject obj, FrameworkElement value) 
    { 
     obj.SetValue(DetailControlProperty, value); 
    } 

    public static readonly DependencyProperty DetailControlProperty = DependencyProperty.RegisterAttached("DetailControl", typeof(FrameworkElement), typeof(LabelValidationHelper), new UIPropertyMetadata(null, OnDetailControlChanged));  

    private static void OnDetailControlChanged(DependencyObject sender, DependencyPropertyChangedEventArgs args) 
    { 
     if (args.NewValue == null) 
      return; 

     var label = (Label)sender; 

     var style = new Style(typeof(Label), label.Style); 

     var binding = new Binding(); 
     binding.Source = args.NewValue; 
     binding.Path = new PropertyPath(Validation.HasErrorProperty); 

     var trigger = new DataTrigger(); 
     trigger.Binding = binding; 
     trigger.Value = true; 

     var setter = new Setter(); 
     setter.Property = Label.ForegroundProperty; 
     setter.Value = Brushes.Red; 

     trigger.Setters.Add(setter); 

     style.Triggers.Add(trigger); 

     label.Style = style; 
    } 

} 

而且你可以把它想:

<Label Content="Select a string" example:LabelValidationHelper.DetailControl="{Binding ElementName=comb}" /> 
+0

偉大的作品,謝謝。 – rwdial 2012-07-17 23:19:57

0

您可以只使用樣式。

<Style TargetType="Label"> 
     <Setter Property="FontSize" Value="20"/> 
     <Setter Property="FontWeight" Value="Bold"/> 
     <Setter Property="Padding" Value="0,5"/> 
     <Style.Triggers> 
      <DataTrigger Binding="{Binding RelativeSource={RelativeSource Self}, Path=(Target).(Validation.HasError)}" Value="True"> 
       <Setter Property="Foreground" Value="Red" /> 
      </DataTrigger> 
      <DataTrigger Binding="{Binding RelativeSource={RelativeSource Self}, Path=(Target).(Validation.HasError)}" Value="False"> 
       <Setter Property="Foreground" Value="Gray" /> 
      </DataTrigger> 
     </Style.Triggers> 
    </Style> 

,並使用它像這樣:

<Label Target="{Binding ElementName=NominaalBox}" Content="Nominaal (gram):"/> 
<TextBox x:Name="NominaalBox" Text="{Binding Path=NominaalGram, Mode=TwoWay, TargetNullValue='', UpdateSourceTrigger=PropertyChanged}"/>