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

WebPartTransformerAttribute (Clase)

 

Identifica los tipos de puntos de conexión que admite un transformador.

Espacio de nombres:   System.Web.UI.WebControls.WebParts
Ensamblado:  System.Web (en System.Web.dll)

System.Object
  System.Attribute
    System.Web.UI.WebControls.WebParts.WebPartTransformerAttribute

[AttributeUsageAttribute(AttributeTargets.Class)]
public sealed class WebPartTransformerAttribute : Attribute

NombreDescripción
System_CAPS_pubmethodWebPartTransformerAttribute(Type, Type)

Inicializa una nueva instancia de la clase WebPartTransformerAttribute.

NombreDescripción
System_CAPS_pubpropertyConsumerType

Obtiene el tipo Type de la interfaz admitido por el punto de conexión del consumidor.

System_CAPS_pubpropertyProviderType

Obtiene el tipo Type de la interfaz admitido por el punto de conexión del proveedor.

System_CAPS_pubpropertyTypeId

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

NombreDescripción
System_CAPS_pubmethodEquals(Object)

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

System_CAPS_pubmethodSystem_CAPS_staticGetConsumerType(Type)

Devuelve el tipo de consumidor que un transformador puede aceptar en un punto de conexión.

System_CAPS_pubmethodGetHashCode()

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

System_CAPS_pubmethodSystem_CAPS_staticGetProviderType(Type)

Devuelve el tipo de proveedor que un transformador puede aceptar en un punto de conexión.

System_CAPS_pubmethodGetType()

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

System_CAPS_pubmethodIsDefaultAttribute()

Cuando se invalida en una clase derivada, indica si el valor de esta instancia es el valor predeterminado para 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_pubmethodToString()

Retorna 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.)

Los transformadores se utilizan para convertir datos entre dos controles de elementos Web con puntos de conexión incompatibles.Los puntos de conexión son incompatibles cuando proporcionan o utilizan los datos a través de interfaces diferentes.Por ejemplo, un proveedor que implemente un punto de conexión del proveedor de tipo IWebPartRow no puede conectarse directamente a un consumidor que espere un punto de conexión del proveedor de tipo IWebPartTable.En su lugar, debe utilizarse un transformador para conectar los dos puntos de conexión.Se puede crear un transformador personalizado derivando una clase de la clase WebPartTransformer.

El atributo WebPartTransformerAttribute se aplica a una clase WebPartTransformer.Define el tipo de punto de conexión del proveedor y el tipo de punto de conexión del consumidor que admite un transformador.El tipo de punto de conexión del consumidor y proveedor admitido por el transformador debe coincidir con los puntos de conexión de los controles de elementos Web consumidor y proveedor para que se pueda establecer una conexión entre los controles.En tiempo de ejecución, el tipo de puntos de conexión que admite un determinado transformador se puede recuperar a través de los métodos GetConsumerType y GetProviderType.

El ejemplo de código siguiente muestra cómo se utiliza un atributo WebPartTransformerAttribute con una clase WebPartTransformer personalizada.El atributo indica que la clase RowToStringTransformer puede transformar un punto de conexión del proveedor de tipo IWebPartRow en un punto de conexión del consumidor de tipo IString.

Este ejemplo de código forma parte de un ejemplo más extenso que está disponible en la información general sobre la clase WebPartTransformer.

// A transformer that transforms a row to a string.
[AspNetHostingPermission(SecurityAction.Demand,
  Level = AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand,
  Level = AspNetHostingPermissionLevel.Minimal)]
[WebPartTransformer(typeof(IWebPartRow), typeof(IString))]
public class RowToStringTransformer : WebPartTransformer, IString
{

    private IWebPartRow _provider;
    private StringCallback _callback;

    private void GetRowData(object rowData)
    {
        PropertyDescriptorCollection props = _provider.Schema;
        if (props != null && props.Count > 0 && rowData != null)
        {
            string returnValue = String.Empty;
            foreach (PropertyDescriptor prop in props)
            {
                if (prop != props[0])
                {
                    returnValue += ", ";
                }
                returnValue += prop.DisplayName + ": " + prop.GetValue(rowData);
            }
            _callback(returnValue);
        }
        else
        {
            _callback(null);
        }
    }

    public override object Transform(object providerData)
    {
        _provider = (IWebPartRow)providerData;
        return this;
    }

    void IString.GetStringValue(StringCallback callback)
    {
        if (callback == null)
        {
            throw new ArgumentNullException("callback");
        }

        if (_provider != null)
        {
            _callback = callback;
            _provider.GetRowData(new RowCallback(GetRowData));
        }
        else
        {
            callback(null);
        }
    }
}

.NET Framework
Disponible desde 2.0

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

Volver al principio
Mostrar: