RelativeSource RelativeSource RelativeSource RelativeSource Class

Définition

Implémente une extension de balisage qui décrit l’emplacement de la source de liaison par rapport à la position de la cible de liaison.Implements a markup extension that describes the location of the binding source relative to the position of the binding target.

public ref class RelativeSource : System::Windows::Markup::MarkupExtension, System::ComponentModel::ISupportInitialize
[System.Windows.Markup.MarkupExtensionReturnType(typeof(System.Windows.Data.RelativeSource))]
public class RelativeSource : System.Windows.Markup.MarkupExtension, System.ComponentModel.ISupportInitialize
type RelativeSource = class
    inherit MarkupExtension
    interface ISupportInitialize
Public Class RelativeSource
Inherits MarkupExtension
Implements ISupportInitialize
Héritage
RelativeSourceRelativeSourceRelativeSourceRelativeSource
Attributs
Implémente

Exemples

L’exemple suivant montre un déclencheur de style qui ToolTip crée un qui signale un message d’erreur de validation.The following example shows a style trigger that creates a ToolTip that reports a validation error message. À l' RelativeSource aide de la propriété, la valeur de l’accesseur Set est liée au contenu TextBox d’erreur TextBox du en cours (à l’aide du style).Using the RelativeSource property, the value of the setter binds to the error content of the current TextBox (the TextBox using the style). Pour plus d’informations sur cet exemple, consultez Procédure: Implémenter lavalidation de liaison.For more information on this example, see How to: Implement Binding Validation.

<Style x:Key="textBoxInError" TargetType="{x:Type TextBox}">
  <Style.Triggers>
    <Trigger Property="Validation.HasError" Value="true">
      <Setter Property="ToolTip"
        Value="{Binding RelativeSource={x:Static RelativeSource.Self},
                        Path=(Validation.Errors)/ErrorContent}"/>
    </Trigger>
  </Style.Triggers>
</Style>

L’exemple suivant illustre la Style définition d’un contrôle personnalisé appelé NumericUpDown.The following example shows the Style definition of a custom control called NumericUpDown. La Text Value propriété TemplatedParent NumericUpDown de est liée au de l’objet qui est le, qui est le contrôle auquel ce Style est appliqué dans ce cas. TextBlockThe Text property of the TextBlock is bound to the Value of the object that is the TemplatedParent, which is the NumericUpDown control that this Style is applied to in this case.

<!--ControlTemplate for NumericUpDown that inherits from
    Control.-->
<Style TargetType="{x:Type local:NumericUpDown}">
  <Setter Property="HorizontalAlignment" Value="Center"/>
  <Setter Property="VerticalAlignment" Value="Center"/>
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type local:NumericUpDown}">
        <Grid Margin="3">
          <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition/>
          </Grid.RowDefinitions>
          <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition/>
          </Grid.ColumnDefinitions>

          <Border BorderThickness="1" BorderBrush="Gray" 
                  Margin="2" Grid.RowSpan="2" 
                  VerticalAlignment="Center" HorizontalAlignment="Stretch">
                  
            <TextBlock Text="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=Value}" 
                       Width="60" TextAlignment="Right" Padding="5"/>
          </Border>
          
          <RepeatButton Command="{x:Static local:NumericUpDown.IncreaseCommand}"  
                        Grid.Column="1" Grid.Row="0">Up</RepeatButton>
                        
          <RepeatButton Command="{x:Static local:NumericUpDown.DecreaseCommand}"
                        Grid.Column="1" Grid.Row="1">Down</RepeatButton>

        </Grid>

      </ControlTemplate>
    </Setter.Value>
  </Setter>
</Style>

Pour obtenir l’exemple complet, consultez contrôle personnalisé NumericUpDown avec thème et prise en charge d’UI Automation.For the complete sample, see NumericUpDown Custom Control with Theme and UI Automation Support Sample.

L’exemple suivant retourne le ItemsControl deuxième rencontré sur le chemin vers le haut, en commençant par l’élément cible de la liaison.The following returns the second ItemsControl encountered on the upward path starting at the target element of the binding.

Binding myBinding = new Binding();
// Returns the second ItemsControl encountered on the upward path
// starting at the target element of the binding
myBinding.RelativeSource = new RelativeSource(
    RelativeSourceMode.FindAncestor, typeof(ItemsControl), 2);
Dim myBinding As New Binding()
' Returns the second ItemsControl encountered on the upward path
' starting at the target element of the binding
myBinding.RelativeSource = New RelativeSource(RelativeSourceMode.FindAncestor, GetType(ItemsControl), 2)

Remarques

L’une des façons de spécifier une source de liaison consiste à utiliser Binding.RelativeSource la propriété.One of the ways to specify a binding source is to use the Binding.RelativeSource property. Il s’agit du type de propriété de cette propriété.This is the property type of that property. RelativeSourceest simultanément une implémentation d’extension de balisage et un objet de données.RelativeSource is simultaneously a markup extension implementation and a data object. Lorsque l’extension est retournée ( ProvideValuevoir), les informations pertinentes sont contenues dans les données.When the extension returns itself (see ProvideValue), the relevant information is contained in the data. L’objectif principal de l’extension de balisage est de permettre la syntaxe d’un constructeur à argument variable sous forme d' FindAncestor attribut, afin que le mode puisse être défini inline avec les deux arguments supplémentaires pour le type ancêtre et le niveau dont les autres modes n’ont pas besoin.The main purpose of the markup extension is to allow a variable-argument constructor syntax in attribute form, so that the FindAncestor mode can be defined inline with the two extra arguments for ancestor type and level that the other modes do not require.

Pour XAMLXAML plus d’informations, consultez RelativeSource MarkupExtension.For XAMLXAML information, see RelativeSource MarkupExtension.

Constructeurs

RelativeSource() RelativeSource() RelativeSource() RelativeSource()

Initialise une nouvelle instance de la classe RelativeSource.Initializes a new instance of the RelativeSource class.

RelativeSource(RelativeSourceMode) RelativeSource(RelativeSourceMode) RelativeSource(RelativeSourceMode) RelativeSource(RelativeSourceMode)

Initialise une nouvelle instance de la classe RelativeSource avec un mode initial.Initializes a new instance of the RelativeSource class with an initial mode.

RelativeSource(RelativeSourceMode, Type, Int32) RelativeSource(RelativeSourceMode, Type, Int32) RelativeSource(RelativeSourceMode, Type, Int32) RelativeSource(RelativeSourceMode, Type, Int32)

Initialise une nouvelle instance de la classe RelativeSource avec un mode initial et des qualificateurs de marche d'arborescence supplémentaires pour rechercher la source relative souhaitée.Initializes a new instance of the RelativeSource class with an initial mode and additional tree-walking qualifiers for finding the desired relative source.

Propriétés

AncestorLevel AncestorLevel AncestorLevel AncestorLevel

Obtient ou définit le niveau d’ancêtre à rechercher, en mode FindAncestor.Gets or sets the level of ancestor to look for, in FindAncestor mode. Utilisez 1 pour indiquer celui le plus proche de l’élément cible de liaison.Use 1 to indicate the one nearest to the binding target element.

AncestorType AncestorType AncestorType AncestorType

Obtient ou définit le type d'ancêtre à rechercher.Gets or sets the type of ancestor to look for.

Mode Mode Mode Mode

Obtient ou définit une valeur RelativeSourceMode qui décrit l’emplacement de la source de liaison par rapport à la position de la cible de liaison.Gets or sets a RelativeSourceMode value that describes the location of the binding source relative to the position of the binding target.

PreviousData PreviousData PreviousData PreviousData

Obtient une valeur statique utilisée pour retourner un RelativeSource construit pour le mode PreviousData.Gets a static value that is used to return a RelativeSource constructed for the PreviousData mode.

Self Self Self Self

Obtient une valeur statique utilisée pour retourner un RelativeSource construit pour le mode Self.Gets a static value that is used to return a RelativeSource constructed for the Self mode.

TemplatedParent TemplatedParent TemplatedParent TemplatedParent

Obtient une valeur statique utilisée pour retourner un RelativeSource construit pour le mode TemplatedParent.Gets a static value that is used to return a RelativeSource constructed for the TemplatedParent mode.

Méthodes

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Détermine si l'objet spécifié est identique à l'objet actuel.Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Fait office de fonction de hachage par défaut.Serves as the default hash function.

(Inherited from Object)
GetType() GetType() GetType() GetType()

Obtient le Type de l'instance actuelle.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Crée une copie superficielle de l'objet Object actuel.Creates a shallow copy of the current Object.

(Inherited from Object)
ProvideValue(IServiceProvider) ProvideValue(IServiceProvider) ProvideValue(IServiceProvider) ProvideValue(IServiceProvider)

Retourne un objet qui doit être défini comme la valeur sur la propriété de l'objet cible pour cette extension de balisage.Returns an object that should be set as the value on the target object's property for this markup extension. Pour RelativeSource, il s'agit d'un autre RelativeSource qui utilise la source appropriée pour le mode spécifié.For RelativeSource, this is another RelativeSource, using the appropriate source for the specified mode.

ShouldSerializeAncestorLevel() ShouldSerializeAncestorLevel() ShouldSerializeAncestorLevel() ShouldSerializeAncestorLevel()

Indique si la propriété AncestorLevel doit être rendue persistante.Indicates whether the AncestorLevel property should be persisted.

ShouldSerializeAncestorType() ShouldSerializeAncestorType() ShouldSerializeAncestorType() ShouldSerializeAncestorType()

Indique si la propriété AncestorType doit être rendue persistante.Indicates whether the AncestorType property should be persisted.

ToString() ToString() ToString() ToString()

Retourne une chaîne qui représente l'objet actuel.Returns a string that represents the current object.

(Inherited from Object)

Implémentations d’interfaces explicites

ISupportInitialize.BeginInit() ISupportInitialize.BeginInit() ISupportInitialize.BeginInit() ISupportInitialize.BeginInit()

Ce membre prend en charge l’infrastructure Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) et n’est pas destiné à être directement utilisé à partir de votre code.This member supports the Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) infrastructure and is not intended to be used directly from your code.

ISupportInitialize.EndInit() ISupportInitialize.EndInit() ISupportInitialize.EndInit() ISupportInitialize.EndInit()

Ce membre prend en charge l’infrastructure Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) et n’est pas destiné à être directement utilisé à partir de votre code.This member supports the Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) infrastructure and is not intended to be used directly from your code.

S’applique à

Voir aussi