Condividi tramite


Condition.Binding Proprietà

Definizione

Ottiene o imposta l'associazione che specifica la proprietà della condizione. Questo è applicabile solo agli MultiDataTrigger oggetti .

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à

Il valore predefinito è null.

Esempio

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

Ognuno ListBoxItem di ListBox essi visualizza un oggetto Place . Nell'esempio Style viene applicato a ogni ListBoxItemoggetto . Gli Conditionoggetti di 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 si visualizza un elenco di elementi attività, è possibile visualizzare un'attività con uno sfondo rosso se è con priorità alta 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.

Utilizzo degli attributi XAML

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

Utilizzo dell'elemento della proprietà XAML

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

Valori XAML

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

Si applica a

Vedi anche