Condividi tramite


Condition.Binding Proprietà

Definizione

Ottiene o imposta il binding che specifica la proprietà della condizione. Applicabile solo agli oggetti MultiDataTrigger.

public:
 property System::Windows::Data::BindingBase ^ Binding { System::Windows::Data::BindingBase ^ get(); void set(System::Windows::Data::BindingBase ^ value); };
public System.Windows.Data.BindingBase Binding { get; set; }
member this.Binding : System.Windows.Data.BindingBase with get, set
Public Property Binding As BindingBase

Valore della proprietà

BindingBase

Il valore predefinito è null.

Esempio

Nell'esempio seguente, l'oggetto dell'oggetto ItemsSource ListBox è associato a Places, un ObservableCollection<T> di oggetti Place . Gli oggetti Place hanno proprietà Name e State.

Ogni ListBoxItem oggetto ListBox visualizza un oggetto Place . Nell'esempio Style viene applicato a ogni ListBoxItemoggetto . Gli Conditionoggetti dell'oggetto MultiDataTrigger sono specificati in modo che se l'elemento dati Name e State of the Place è rispettivamente "Portland" e "OR", lo sfondo del corrispondente ListBoxItem viene impostato su Cyan.

<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>

Commenti

MultiDataTriggers consente di impostare i valori delle proprietà in base ai valori dei dati restituiti. Ad esempio, se viene visualizzato un elenco di elementi attività, è possibile visualizzare un'attività con uno sfondo rosso se è con priorità elevata e non è stata esaminata per più di due settimane.

Si crea un'associazione e si usa la proprietà per eseguire l'associazione Path a una proprietà di un determinato oggetto (l'oggetto di origine dell'associazione). Ad esempio, è possibile eseguire l'associazione alla proprietà Priority di un oggetto Task. Per altre informazioni, vedere Panoramica del data binding.

Si noti che se si tratta di una condizione per un MultiDataTrigger, è necessario impostare le Binding proprietà e Value . L'impostazione del Property valore provocherebbe un'eccezione in tal caso.

Uso della sintassi XAML per gli attributi

<object property="{Binding  declaration}"/>  

Utilizzo della sintassi XAML per elementi proprietà

<object>  
  <object.Binding>  
    <Binding …/>  
  </object.Binding>  
</object>  

Valori XAML

dichiarazione
Dichiarazione di associazione. Per altre informazioni, vedere Cenni preliminari sulle dichiarazioni di associazione.

Si applica a

Vedi anche