WebPartTransformerAttribute Klas

Definitie

Hiermee worden de typen verbindingspunten geïdentificeerd die door een transformator worden ondersteund.

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
Overname
WebPartTransformerAttribute
Kenmerken

Voorbeelden

In het volgende codevoorbeeld ziet u het gebruik van een WebPartTransformerAttribute kenmerk met een aangepaste WebPartTransformer klasse. Het kenmerk geeft aan dat de klasse een verbindingspunt van een RowToStringTransformer provider van het type IWebPartRow kan transformeren naar een consumentenaansluitpunt van het type IString.

Dit codevoorbeeld maakt deel uit van een groter voorbeeld in het WebPartTransformer klasseoverzicht.

// 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

Opmerkingen

Transformatoren worden gebruikt om gegevens te vertalen tussen twee besturingselementen voor webonderdelen met incompatibele verbindingspunten. Verbindingspunten zijn niet compatibel wanneer ze gegevens leveren of gebruiken via verschillende interfaces. Een provider die bijvoorbeeld een verbindingspunt van IWebPartRow een provider implementeert, kan niet rechtstreeks verbinding maken met een consument die een providerverbindingspunt van het type IWebPartTableverwacht. In plaats daarvan moet een transformator worden gebruikt om de twee verbindingspunten te verbinden. Een aangepaste transformator kan worden gemaakt door een klasse van de WebPartTransformer klasse af te leiden.

Het WebPartTransformerAttribute kenmerk wordt toegepast op een WebPartTransformer klasse. Hiermee definieert u het type providerverbindingspunt en het type consumentenaansluitpunt dat door een transformator wordt ondersteund. Het type consumenten- en providerverbindingspunten dat door de transformator wordt ondersteund, moet overeenkomen met de verbindingspunten van de besturingselementen van de webonderdelen van de consument en provider om een verbinding tussen de besturingselementen te maken. Tijdens runtime kan het type verbindingspunten dat een bepaalde transformator ondersteunt, worden opgehaald via de GetConsumerType en GetProviderType methoden.

Constructors

Name Description
WebPartTransformerAttribute(Type, Type)

Initialiseert een nieuw exemplaar van de WebPartTransformerAttribute klasse.

Eigenschappen

Name Description
ConsumerType

Hiermee haalt u de Type interface op die wordt ondersteund door het verbindingspunt van de consument.

ProviderType

Hiermee haalt u de Type interface op die wordt ondersteund door het verbindingspunt van de provider.

TypeId

Wanneer deze wordt geïmplementeerd in een afgeleide klasse, krijgt u Attributehiervoor een unieke id.

(Overgenomen van Attribute)

Methoden

Name Description
Equals(Object)

Retourneert een waarde die aangeeft of dit exemplaar gelijk is aan een opgegeven object.

(Overgenomen van Attribute)
GetConsumerType(Type)

Retourneert het consumententype dat een transformator kan accepteren op een verbindingspunt.

GetHashCode()

Retourneert de hash-code voor dit exemplaar.

(Overgenomen van Attribute)
GetProviderType(Type)

Retourneert het providertype dat een transformator kan accepteren op een verbindingspunt.

GetType()

Hiermee haalt u de Type huidige instantie op.

(Overgenomen van Object)
IsDefaultAttribute()

Wanneer deze wordt overschreven in een afgeleide klasse, geeft u aan of de waarde van dit exemplaar de standaardwaarde is voor de afgeleide klasse.

(Overgenomen van Attribute)
Match(Object)

Wanneer deze wordt overschreven in een afgeleide klasse, wordt een waarde geretourneerd die aangeeft of dit exemplaar gelijk is aan een opgegeven object.

(Overgenomen van Attribute)
MemberwiseClone()

Hiermee maakt u een ondiepe kopie van de huidige Object.

(Overgenomen van Object)
ToString()

Retourneert een tekenreeks die het huidige object vertegenwoordigt.

(Overgenomen van Object)

Expliciete interface-implementaties

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

Hiermee wordt een set namen toegewezen aan een bijbehorende set verzend-id's.

(Overgenomen van Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Hiermee haalt u de typegegevens voor een object op, die kan worden gebruikt om de typegegevens voor een interface op te halen.

(Overgenomen van Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Hiermee wordt het aantal type-informatieinterfaces opgehaald dat een object biedt (0 of 1).

(Overgenomen van Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Biedt toegang tot eigenschappen en methoden die door een object worden weergegeven.

(Overgenomen van Attribute)

Van toepassing op