Este artículo se tradujo automáticamente. Para ver el artículo en inglés, active la casilla Inglés. Además, puede mostrar el texto en inglés en una ventana emergente si mueve el puntero del mouse sobre el texto.
Traducción
Inglés

Clase AttributeProviderAttribute

 

Publicado: octubre de 2016

Habilita el redireccionamiento del atributo. Esta clase no puede heredarse.

Espacio de nombres:   System.ComponentModel
Ensamblado:  System (en System.dll)

System.Object
  System.Attribute
    System.ComponentModel.AttributeProviderAttribute

[AttributeUsageAttribute(AttributeTargets.Property)]
public class AttributeProviderAttribute : Attribute

NombreDescripción
System_CAPS_pubmethodAttributeProviderAttribute(String)

Inicializa una nueva instancia de la AttributeProviderAttribute clase con el nombre del tipo.

System_CAPS_pubmethodAttributeProviderAttribute(String, String)

Inicializa una nueva instancia de la AttributeProviderAttribute clase con el nombre de tipo y el nombre de la propiedad.

System_CAPS_pubmethodAttributeProviderAttribute(Type)

Inicializa una nueva instancia de la AttributeProviderAttribute clase con el tipo especificado.

NombreDescripción
System_CAPS_pubpropertyPropertyName

Obtiene el nombre de la propiedad para la que se recuperarán los atributos.

System_CAPS_pubpropertyTypeId

Cuando se implementa en una clase derivada, obtiene un identificador único para este Attribute.(Heredado de Attribute).

System_CAPS_pubpropertyTypeName

Obtiene el nombre completo del tipo pasado al constructor de ensamblado.

NombreDescripción
System_CAPS_pubmethodEquals(Object)

Esta API admite la infraestructura producto y no está diseñada para usarse directamente desde el código. Devuelve un valor que indica si esta instancia equivale al objeto especificado. (Heredado de Attribute).

System_CAPS_protmethodFinalize()

Permite que un objeto intente liberar recursos y realizar otras operaciones de limpieza antes de ser reclamado por el recolector de basura. (Heredado de Object).

System_CAPS_pubmethodGetHashCode()

Devuelve el código hash de esta instancia.(Heredado de Attribute).

System_CAPS_pubmethodGetType()

Obtiene el Type de la instancia actual.(Heredado de Object).

System_CAPS_pubmethodIsDefaultAttribute()

Si se reemplaza en una clase derivada, indica si el valor de esta instancia es el valor predeterminado de la clase derivada.(Heredado de Attribute).

System_CAPS_pubmethodMatch(Object)

Cuando se invalida en una clase derivada, devuelve un valor que indica si esta instancia es igual al objeto especificado. (Heredado de Attribute).

System_CAPS_protmethodMemberwiseClone()

Crea una copia superficial del Object actual.(Heredado de Object).

System_CAPS_pubmethodToString()

Devuelve una cadena que representa al objeto actual. (Heredado de Object).

NombreDescripción
System_CAPS_pubinterfaceSystem_CAPS_privmethod_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Asigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío.(Heredado de Attribute).

System_CAPS_pubinterfaceSystem_CAPS_privmethod_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Obtiene la información del tipo de un objeto, que puede utilizarse para obtener la información del tipo de una interfaz. (Heredado de Attribute).

System_CAPS_pubinterfaceSystem_CAPS_privmethod_Attribute.GetTypeInfoCount(UInt32)

Recupera el número de interfaces de tipo de información que suministra un objeto (0 ó 1)

(Heredado de Attribute).

System_CAPS_pubinterfaceSystem_CAPS_privmethod_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Proporciona acceso a las propiedades y los métodos expuestos por un objeto.(Heredado de Attribute).

Hay algunos casos en que una propiedad es de tipo deliberadamente imprecisa intencionadamente el modelo de objetos de .NET Framework. Por ejemplo, el DataGridView.DataSource propiedad se escribe como object. El motivo es que esta propiedad puede aceptar varios tipos de entrada. Desafortunadamente, esto no proporciona ningún lugar común para agregar metadatos que describen las características de la propiedad. Cada DataSource tiene las propiedades de .NET Framework tengan metadatos idénticos para los convertidores de tipos, editores de tipos de interfaz de usuario y otros servicios que requieren metadatos. El AttributeProviderAttribute soluciona esta situación.

Cuando este atributo se coloca en una propiedad, las reglas de obtención de atributos para el descriptor de propiedad MemberDescriptor.Attributes difieren de la colección. Normalmente, el descriptor de propiedad recopila los atributos locales y, a continuación, combina con los atributos del tipo de propiedad. En este caso, los atributos se toman del tipo devuelto desde el AttributeProviderAttribute, no del tipo de propiedad real. Este atributo se utiliza en DataGridView.DataSource para que señale el DataGridView.DataSource tipo específico del objeto a IListSource, y los metadatos correspondientes se colocan en IListSource para habilitar el enlace de datos. De este modo, partes externas pueden agregar fácilmente metadatos a todos los orígenes de datos.

Los atributos obtenidos de un tipo declaran en el AttributeProviderAttribute tienen una prioridad entre los atributos del tipo de propiedad y los atributos en la propiedad. La lista siguiente, en orden de prioridad, muestra el conjunto completo de atributos combinados disponibles:

  • Atributos de propiedad

  • Atributos de proveedor de atributo

  • Atributos de tipo de propiedad

En el ejemplo de código siguiente se muestra cómo utilizar AttributeProviderAttribute para marcar un DataSource propiedad con un tipo específico de IListSource. Para obtener una lista de código completo, vea Cómo: Aplicar atributos en controles de formularios Windows Forms.

[Category("Data")]
[Description("Indicates the source of data for the control.")]
[RefreshProperties(RefreshProperties.Repaint)]
[AttributeProvider(typeof(IListSource))]
public object DataSource
{
    get
    {
        return this.dataGridView1.DataSource;
    }

    set
    {
        this.dataGridView1.DataSource = value;
    }
}

.NET Framework
Disponible desde 2.0

Cualquier miembro ( Compartido en Visual Basic) estático público de este tipo es seguro para subprocesos. No se garantiza que los miembros de instancia sean seguros para subprocesos.

Volver al principio
Mostrar: