WebPartTransformerAttribute Classe

Definição

Identifica os tipos de pontos de ligação que um transformador suporta.

public ref class WebPartTransformerAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Class)]
public sealed class WebPartTransformerAttribute : Attribute
[<System.AttributeUsage(System.AttributeTargets.Class)>]
type WebPartTransformerAttribute = class
    inherit Attribute
Public NotInheritable Class WebPartTransformerAttribute
Inherits Attribute
Herança
WebPartTransformerAttribute
Atributos

Exemplos

O exemplo de código seguinte demonstra o uso de um WebPartTransformerAttribute atributo com uma classe personalizada WebPartTransformer . O atributo indica que a RowToStringTransformer classe pode transformar um ponto de ligação ao fornecedor do tipo IWebPartRow num ponto de ligação ao consumidor do tipo IString.

Este exemplo de código faz parte de um exemplo maior encontrado na WebPartTransformer visão geral da classe.

// 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);
        }
    }
}
' A transformer that transforms a row to a string.
<AspNetHostingPermission(SecurityAction.Demand, _
   Level:=AspNetHostingPermissionLevel.Minimal)> _
<AspNetHostingPermission(SecurityAction.InheritanceDemand, _
   Level:=AspNetHostingPermissionLevel.Minimal)> _
<WebPartTransformer(GetType(IWebPartRow), GetType(IString))> _
Public Class RowToStringTransformer
    Inherits WebPartTransformer
    Implements IString

    Private _provider As IWebPartRow
    Private _callback As StringCallback

    Private Sub GetRowData(ByVal rowData As Object)
        Dim props As PropertyDescriptorCollection = _provider.Schema

        If ((Not (props Is Nothing)) AndAlso (props.Count > 0) _
          AndAlso (Not (rowData Is Nothing))) Then
            Dim returnValue As String = String.Empty
            For Each prop As PropertyDescriptor In props
                If Not (prop Is props(0)) Then
                    returnValue += ", "
                End If
                returnValue += prop.DisplayName.ToString() + ": " + _
                    prop.GetValue(rowData).ToString()
            Next
            _callback(returnValue)
        Else
            _callback(Nothing)
        End If
    End Sub

    Public Overrides Function Transform(ByVal providerData As Object) As Object
        _provider = CType(providerData, IWebPartRow)
        Return Me
    End Function


    Sub GetStringValue(ByVal callback As StringCallback) _
       Implements IString.GetStringValue
        If (callback Is Nothing) Then
            Throw New ArgumentNullException("callback")
        End If

        If (Not (_provider Is Nothing)) Then
            _callback = callback
            _provider.GetRowData(New RowCallback(AddressOf GetRowData))
        Else
            callback(Nothing)
        End If
    End Sub
End Class

Observações

Transformadores são usados para traduzir dados entre dois controlos Web Parts com pontos de ligação incompatíveis. Os pontos de ligação são incompatíveis quando fornecem ou consomem dados através de interfaces diferentes. Por exemplo, um fornecedor que implementa um ponto IWebPartRow de ligação do tipo não poderia ligar-se diretamente a um consumidor esperando um ponto IWebPartTablede ligação do tipo . Em vez disso, deve ser usado um transformador para ligar os dois pontos de ligação. Um transformador personalizado pode ser criado derivando uma classe a partir dessa WebPartTransformer classe.

O WebPartTransformerAttribute atributo é aplicado a uma WebPartTransformer classe. Define o tipo de ponto de ligação do fornecedor e o tipo de ponto de ligação do consumidor que um transformador suporta. O tipo de pontos de ligação do consumidor e do fornecedor suportados pelo transformador deve corresponder aos pontos de ligação dos controlos Web Parts do consumidor e do fornecedor para que seja feita uma ligação entre os controlos. Em tempo de execução, o tipo de pontos de ligação que um determinado transformador suporta pode ser recuperado através dos GetConsumerType métodos e GetProviderType .

Construtores

Name Description
WebPartTransformerAttribute(Type, Type)

Inicializa uma nova instância da WebPartTransformerAttribute classe.

Propriedades

Name Description
ConsumerType

Obtém o Type da interface suportado pelo ponto de ligação do consumidor.

ProviderType

Obtém a Type interface suportada pelo ponto de ligação do fornecedor.

TypeId

Quando implementado numa classe derivada, obtém um identificador único para esta Attribute.

(Herdado de Attribute)

Métodos

Name Description
Equals(Object)

Devolve um valor que indica se esta instância é igual a um objeto especificado.

(Herdado de Attribute)
GetConsumerType(Type)

Devolve o tipo de consumidor que um transformador pode aceitar num ponto de ligação.

GetHashCode()

Devolve o código de hash para esta instância.

(Herdado de Attribute)
GetProviderType(Type)

Devolve o tipo de fornecedor que um transformador pode aceitar num ponto de ligação.

GetType()

Obtém o Type da instância atual.

(Herdado de Object)
IsDefaultAttribute()

Quando sobrescrito numa classe derivada, indica se o valor desta instância é o valor padrão para a classe derivada.

(Herdado de Attribute)
Match(Object)

Quando sobrescrito numa classe derivada, devolve um valor que indica se esta instância é igual a um objeto especificado.

(Herdado de Attribute)
MemberwiseClone()

Cria uma cópia superficial do atual Object.

(Herdado de Object)
ToString()

Devolve uma cadeia que representa o objeto atual.

(Herdado de Object)

Implementações de Interface Explícita

Name Description
_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Mapeia um conjunto de nomes para um conjunto correspondente de identificadores de despacho.

(Herdado de Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Recupera a informação de tipo de um objeto, que pode ser usada para obter a informação de tipo para uma interface.

(Herdado de Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Recupera o número de interfaces de informações de tipo que um objeto fornece (0 ou 1).

(Herdado de Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Proporciona acesso a propriedades e métodos expostos por um objeto.

(Herdado de Attribute)

Aplica-se a