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

WebPartTransformerAttribute (Clase)

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

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

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

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

El tipo WebPartTransformerAttribute expone los siguientes miembros.

  NombreDescripción
Método públicoWebPartTransformerAttributeInicializa una nueva instancia de la clase WebPartTransformerAttribute.
Arriba

  NombreDescripción
Propiedad públicaConsumerTypeObtiene el tipo Type de la interfaz admitido por el punto de conexión del consumidor.
Propiedad públicaProviderTypeObtiene el tipo Type de la interfaz admitido por el punto de conexión del proveedor.
Propiedad públicaTypeIdCuando se implementa en una clase derivada, obtiene un identificador único para este Attribute. (Se hereda de Attribute).
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 públicoMiembro estáticoGetConsumerTypeDevuelve el tipo de consumidor que un transformador puede aceptar en un punto de conexión.
Método públicoGetHashCodeDevuelve el código hash de esta instancia. (Se hereda de Attribute).
Método públicoMiembro estáticoGetProviderTypeDevuelve el tipo de proveedor que un transformador puede aceptar en un punto de conexión.
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 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

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

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

Windows Phone 8.1, Windows Phone 8, 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 static (Shared en Visual Basic) públicos 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.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft