DependencyProperty.RegisterAttachedReadOnly DependencyProperty.RegisterAttachedReadOnly DependencyProperty.RegisterAttachedReadOnly DependencyProperty.RegisterAttachedReadOnly Method

Definición

Registra una propiedad adjunta de solo lectura.Registers a read-only attached property.

Sobrecargas

RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata)

Registra una propiedad adjunta de solo lectura, con el tipo de propiedad, el tipo de propietario y los metadatos de propiedad especificados.Registers a read-only attached property, with the specified property type, owner type, and property metadata.

RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback)

Registra una propiedad adjunta de solo lectura, con el tipo de propiedad, el tipo de propietario, los metadatos de propiedad y una devolución de llamada de validación especificados.Registers a read-only attached property, with the specified property type, owner type, property metadata, and a validation callback.

RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata)

Registra una propiedad adjunta de solo lectura, con el tipo de propiedad, el tipo de propietario y los metadatos de propiedad especificados.Registers a read-only attached property, with the specified property type, owner type, and property metadata.

public:
 static System::Windows::DependencyPropertyKey ^ RegisterAttachedReadOnly(System::String ^ name, Type ^ propertyType, Type ^ ownerType, System::Windows::PropertyMetadata ^ defaultMetadata);
public static System.Windows.DependencyPropertyKey RegisterAttachedReadOnly (string name, Type propertyType, Type ownerType, System.Windows.PropertyMetadata defaultMetadata);
static member RegisterAttachedReadOnly : string * Type * Type * System.Windows.PropertyMetadata -> System.Windows.DependencyPropertyKey
Public Shared Function RegisterAttachedReadOnly (name As String, propertyType As Type, ownerType As Type, defaultMetadata As PropertyMetadata) As DependencyPropertyKey

Parámetros

name
String String String String

Nombre de la propiedad de dependencia que se va a registrar.The name of the dependency property to register.

propertyType
Type Type Type Type

Tipo de la propiedad.The type of the property.

ownerType
Type Type Type Type

Tipo de propietario que registra la propiedad de dependencia.The owner type that is registering the dependency property.

defaultMetadata
PropertyMetadata PropertyMetadata PropertyMetadata PropertyMetadata

Metadatos de propiedad de la propiedad de dependencia.Property metadata for the dependency property.

Devoluciones

Clave de propiedad de dependencia que debe usarse para establecer el valor de un campo estático de solo lectura en la clase, que se usa para hacer referencia a la propiedad de dependencia más tarde.A dependency property key that should be used to set the value of a static read-only field in your class, which is then used to reference the dependency property later.

Comentarios

Este método devuelve el tipo DependencyPropertyKey, mientras que RegisterAttached devuelve el tipo DependencyProperty.This method returns the type DependencyPropertyKey, whereas RegisterAttached returns the type DependencyProperty. Normalmente, no se hacen públicas, las claves que representan las propiedades de solo lectura porque las claves se pueden usar para establecer el valor de propiedad de dependencia mediante una llamada a SetValue(DependencyPropertyKey, Object).Typically, the keys that represent read-only properties are not made public, because the keys can be used to set the dependency property value by calling SetValue(DependencyPropertyKey, Object). El diseño de clase afectará a sus requisitos, pero generalmente se recomienda limitar el acceso y la visibilidad de cualquier DependencyPropertyKey a sólo aquellas partes del código que son necesarias para establecer esa propiedad de dependencia como parte de la clase o una aplicación lógica.Your class design will affect your requirements, but it is generally recommended to limit the access and visibility of any DependencyPropertyKey to only those parts of your code that are necessary to set that dependency property as part of class or application logic. También se recomienda que exponga un identificador de propiedad de dependencia para la propiedad de dependencia de solo lectura, exponiendo el valor de DependencyPropertyKey.DependencyProperty como un public static readonly campo en su clase.It is also recommended that you expose a dependency property identifier for the read-only dependency property, by exposing the value of DependencyPropertyKey.DependencyProperty as a public static readonly field on your class.

Solo lectura de las propiedades adjuntas son un escenario poco frecuente, porque el escenario principal para una propiedad adjunta es su uso en XAMLXAML.Read-only attached properties are a rare scenario, because the primary scenario for an attached property is its use in XAMLXAML. Sin un establecedor público, no se puede establecer una propiedad adjunta XAMLXAML sintaxis.Without a public setter, an attached property cannot be set in XAMLXAML syntax.

Para obtener más información sobre el registro de la propiedad de dependencia, consulte DependencyProperty.For more information on dependency property registration, see DependencyProperty.

Usar RegisterAttached para heredan las propiedades de dependenciaUse RegisterAttached for Value-inheriting Dependency Properties

Adjunto es un escenario concreto para registrar una propiedad de dependencia como admitir la herencia de valores de propiedad.One particular scenario for registering a dependency property as attached is to support property value inheritance. Debe registrar heredan las propiedades de dependencia con RegisterAttached incluso si la clase define los descriptores de acceso de contenedor de propiedades que exponen la propiedad de dependencia e incluso si no desea exponer los métodos estáticos Get * y Set * para proporcionar true adjunta compatibilidad con descriptores de acceso.You should register value-inheriting dependency properties with RegisterAttached even if the class defines property wrapper accessors that expose the dependency property, and even if you do not intend to expose Get* and Set* static methods to provide true attached property support accessors. Aunque podría parecer que la herencia de valores de propiedad funciona para las propiedades de dependencia, el comportamiento de herencia para una propiedad no asociada a través de algunos límites de elementos en el árbol de tiempo de ejecución es indefinido.Although property value inheritance might appear to work for nonattached dependency properties, the inheritance behavior for a nonattached property through certain element boundaries in the runtime tree is undefined. Registra la propiedad como asociada, realmente hace que la propiedad adjunta una propiedad global para el sistema de propiedades y garantiza que la herencia de valores de propiedad funciona a través de todos los límites de un árbol de elementos.Registering the property as attached effectively makes the attached property a global property to the property system, and assures that property value inheritance works across all boundaries in an element tree. Utilice siempre RegisterAttached para registrar las propiedades donde especifique Inherits en los metadatos.Always use RegisterAttached to register properties where you specify Inherits in the metadata. Para más información, vea Herencia de valores de propiedad.For more information, see Property Value Inheritance.

RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback) RegisterAttachedReadOnly(String, Type, Type, PropertyMetadata, ValidateValueCallback)

Registra una propiedad adjunta de solo lectura, con el tipo de propiedad, el tipo de propietario, los metadatos de propiedad y una devolución de llamada de validación especificados.Registers a read-only attached property, with the specified property type, owner type, property metadata, and a validation callback.

public:
 static System::Windows::DependencyPropertyKey ^ RegisterAttachedReadOnly(System::String ^ name, Type ^ propertyType, Type ^ ownerType, System::Windows::PropertyMetadata ^ defaultMetadata, System::Windows::ValidateValueCallback ^ validateValueCallback);
public static System.Windows.DependencyPropertyKey RegisterAttachedReadOnly (string name, Type propertyType, Type ownerType, System.Windows.PropertyMetadata defaultMetadata, System.Windows.ValidateValueCallback validateValueCallback);
static member RegisterAttachedReadOnly : string * Type * Type * System.Windows.PropertyMetadata * System.Windows.ValidateValueCallback -> System.Windows.DependencyPropertyKey

Parámetros

name
String String String String

Nombre de la propiedad de dependencia que se va a registrar.The name of the dependency property to register.

propertyType
Type Type Type Type

Tipo de la propiedad.The type of the property.

ownerType
Type Type Type Type

Tipo de propietario que registra la propiedad de dependencia.The owner type that is registering the dependency property.

defaultMetadata
PropertyMetadata PropertyMetadata PropertyMetadata PropertyMetadata

Metadatos de propiedad de la propiedad de dependencia.Property metadata for the dependency property.

validateValueCallback
ValidateValueCallback ValidateValueCallback ValidateValueCallback ValidateValueCallback

Referencia a una devolución de llamada creada por el usuario que debe realizar cualquier validación personalizada del valor de la propiedad de dependencia además de la validación habitual de tipo.A reference to a user-created callback that should perform any custom validation of the dependency property value beyond typical type validation.

Devoluciones

Clave de propiedad de dependencia que debe usarse para establecer el valor de un campo estático de solo lectura en la clase, que se usa para hacer referencia a la propiedad de dependencia.A dependency property key that should be used to set the value of a static read-only field in your class, which is then used to reference the dependency property.

Comentarios

Este método devuelve el tipo DependencyPropertyKey, mientras que RegisterAttached devuelve el tipo DependencyProperty.This method returns the type DependencyPropertyKey, whereas RegisterAttached returns the type DependencyProperty. Normalmente, las claves que representan el tipo DependencyProperty.Typically, the keys that represent the type DependencyProperty. Normalmente, no se hacen públicas, las claves que representan las propiedades de solo lectura porque las claves se pueden usar para establecer el valor de propiedad de dependencia mediante una llamada a SetValue(DependencyPropertyKey, Object).Typically, the keys that represent read-only properties are not made public, because the keys can be used to set the dependency property value by calling SetValue(DependencyPropertyKey, Object). El diseño de clase afectará a sus requisitos, pero generalmente se recomienda limitar el acceso y la visibilidad de cualquier DependencyPropertyKey a sólo aquellas partes del código que son necesarias para establecer esa propiedad de dependencia como parte de la clase o una aplicación lógica.Your class design will affect your requirements, but it is generally recommended to limit the access and visibility of any DependencyPropertyKey to only those parts of your code that are necessary to set that dependency property as part of class or application logic. También se recomienda que exponga un identificador de propiedad de dependencia para la propiedad de dependencia de solo lectura, exponiendo el valor de DependencyPropertyKey.DependencyProperty como un public static readonly campo en su clase.It is also recommended that you expose a dependency property identifier for the read-only dependency property, by exposing the value of DependencyPropertyKey.DependencyProperty as a public static readonly field on your class.

Solo lectura de las propiedades adjuntas son un escenario poco frecuente, porque el escenario principal para una propiedad adjunta es su uso en XAMLXAML.Read-only attached properties are a rare scenario, because the primary scenario for an attached property is its use in XAMLXAML. Sin un establecedor público, no se puede establecer una propiedad adjunta XAMLXAML sintaxis.Without a public setter, an attached property cannot be set in XAMLXAML syntax.

Para obtener más información sobre el registro de la propiedad de dependencia, consulte DependencyProperty.For more information on dependency property registration, see DependencyProperty.

Usar RegisterAttached para heredan las propiedades de dependenciaUse RegisterAttached for Value-inheriting Dependency Properties

Un escenario concreto para registrar una propiedad de dependencia como asociada en lugar de Register es admitir la herencia de valores de propiedad.One particular scenario for registering a dependency property as attached instead of Register is to support property value inheritance. Debe registrar heredan las propiedades de dependencia con RegisterAttached incluso si la clase define los descriptores de acceso de contenedor de propiedades que exponen la propiedad de dependencia e incluso si no desea exponer los métodos estáticos Get * y Set * para proporcionar true adjunta compatibilidad con descriptores de acceso.You should register value-inheriting dependency properties with RegisterAttached even if the class defines property wrapper accessors that expose the dependency property, and even if you do not intend to expose Get* and Set* static methods to provide true attached property support accessors. Aunque podría parecer que la herencia de valores de propiedad funciona para las propiedades de dependencia, el comportamiento de herencia para una propiedad no asociada a través de algunos límites de elementos en el árbol de tiempo de ejecución es indefinido.Although property value inheritance might appear to work for nonattached dependency properties, the inheritance behavior for a nonattached property through certain element boundaries in the runtime tree is undefined. Registra la propiedad como asociada, realmente hace que la propiedad adjunta una propiedad global para el sistema de propiedades y garantiza que la herencia de valores de propiedad funciona a través de todos los límites de un árbol de elementos.Registering the property as attached effectively makes the attached property a global property to the property system, and assures that property value inheritance works across all boundaries in an element tree. Utilice siempre RegisterAttached para registrar las propiedades donde especifique Inherits en los metadatos.Always use RegisterAttached to register properties where you specify Inherits in the metadata. Para más información, vea Herencia de valores de propiedad.For more information, see Property Value Inheritance.

Se aplica a