Exportar (0) Imprimir
Expandir todo
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

AttributeProviderAttribute (Clase)

Habilita la redirección del atributo. Esta clase no puede heredarse.

System.Object
  System.Attribute
    System.ComponentModel.AttributeProviderAttribute

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

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

El tipo AttributeProviderAttribute expone los siguientes miembros.

  NombreDescripción
Método públicoAttributeProviderAttribute(String)Inicializa una nueva instancia de la clase AttributeProviderAttribute con el nombre de tipo especificado.
Método públicoAttributeProviderAttribute(Type)Inicializa una nueva instancia de la clase AttributeProviderAttribute con el tipo especificado.
Método públicoAttributeProviderAttribute(String, String)Inicializa una nueva instancia de la clase AttributeProviderAttribute con el nombre de tipo y el nombre de propiedad especificados.
Arriba

  NombreDescripción
Propiedad públicaPropertyNameObtiene el nombre de la propiedad cuyos atributos se van a recuperar.
Propiedad públicaTypeIdCuando se implementa en una clase derivada, obtiene un identificador único para este Attribute. (Se hereda de Attribute).
Propiedad públicaTypeNameObtiene el nombre de tipo calificado con el nombre de ensamblado que se ha pasado al constructor.
Arriba

  NombreDescripción
Método públicoEqualsInfraestructura. Devuelve un valor que indica si esta instancia equivale al objeto especificado. (Se hereda de Attribute).
Método protegidoFinalize Permite que un objeto intente liberar recursos y realizar otras operaciones de limpieza antes de ser reclamado por la recolección de elementos no utilizados. (Se hereda de Object).
Método públicoGetHashCodeDevuelve el código hash de esta instancia. (Se hereda de Attribute).
Método públicoGetType Obtiene el Type de la instancia actual. (Se hereda de Object).
Método públicoIsDefaultAttributeCuando se invalida en una clase derivada, indica si el valor de esta instancia es el valor predeterminado para la clase derivada. (Se hereda de Attribute).
Método públicoMatch Cuando se invalida en una clase derivada, devuelve un valor que indica si esta instancia es igual al objeto especificado. (Se hereda de Attribute).
Método protegidoMemberwiseClone Crea una copia superficial del Object actual. (Se hereda de Object).
Método públicoToString Retorna una cadena que representa al objeto actual. (Se hereda de Object).
Arriba

  NombreDescripción
Implementación explícita de interfacesMétodo privado_Attribute.GetIDsOfNamesAsigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoObtiene la información de tipos de un objeto, que puede utilizarse para obtener la información de tipos de una interfaz. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoCount

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

(Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.InvokeProporciona acceso a las propiedades y los métodos expuestos por un objeto. (Se hereda de Attribute).
Arriba

En el modelo de objetos de .NET Framework, hay algún caso en el que una propiedad se especifica de forma imprecisa intencionadamente. Por ejemplo, la propiedad DataGridView.DataSource se especifica como object. La razón de que esto ocurra es que esta propiedad puede aceptar varios tipos de entrada. Pero, lamentablemente, por este mismo motivo, no se proporciona un lugar común para agregar metadatos que describan las características de la propiedad. Es necesario que todas las propiedades DataSource de .NET Framework tengan metadatos idénticos para los convertidores de tipos, editores de tipos de la interfaz de usuario y otros servicios que requieren metadatos. El objeto AttributeProviderAttribute soluciona esta situación.

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

La prioridad de los atributos obtenidos a partir de un tipo declarado en el objeto AttributeProviderAttribute se encuentra a medio camino entre la prioridad de los atributos del tipo de propiedad y la prioridad de los atributos de la propiedad. En la siguiente lista se muestra el conjunto completo de atributos combinados disponibles, en orden de prioridad:

  • Atributos de propiedad

  • Atributos de proveedor de atributos

  • Atributos de tipo de propiedad

En el siguiente ejemplo de código se muestra la forma de utilizar el objeto AttributeProviderAttribute para marcar una propiedad DataSource con un tipo específico de interfaz IListSource. Para obtener una lista de código completa, 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

Compatible con: 4.5, 4, 3.5, 3.0, 2.0

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (no se admite el rol Server Core), Windows Server 2008 R2 (se admite el rol Server Core con SP1 o versiones posteriores; no se admite Itanium)

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Todos los miembros públicos static (Shared en Visual Basic) de este tipo son seguros para subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft