DataTemplateSelector Klasse

Definition

Bietet eine Möglichkeit zum Auswählen einer DataTemplate auf der Grundlage des Datenobjekts und des datengebundenen Elements.Provides a way to choose a DataTemplate based on the data object and the data-bound element.

public ref class DataTemplateSelector
public class DataTemplateSelector
type DataTemplateSelector = class
Public Class DataTemplateSelector
Vererbung
DataTemplateSelector

Beispiele

In diesem Beispiel ist die Bindungs Quelle eine Liste von Task-Objekten.In this example, the binding source is a list of Task objects. Eine der Eigenschaften eines Task Objekts ist Priority.One of the properties of a Task object is Priority. Es sind zwei Datenvorlagen definiert, myTaskTemplate und importantTaskTemplate.There are two data templates defined, myTaskTemplate and importantTaskTemplate.

Erstellen Sie eine Unterklasse von DataTemplateSelector, und überschreiben Sie die SelectTemplate-Methode, um zu bestimmen, welche DataTemplate basierend auf dem Priority Wert des Datenobjekts verwendet werden soll.To supply logic to choose which DataTemplate to use based on the Priority value of the data object, create a subclass of DataTemplateSelector and override the SelectTemplate method. Im folgenden Beispiel stellt die SelectTemplate-Methode Logik bereit, um die entsprechende Vorlage basierend auf dem Wert der Priority-Eigenschaft zurückzugeben.In the following example, the SelectTemplate method provides logic to return the appropriate template based on the value of the Priority property. Die zurück zugebende Vorlage befindet sich in den Ressourcen des umschließenden Window-Elements.The template to return is found in the resources of the enveloping Window element.

using System.Windows;
using System.Windows.Controls;

namespace SDKSample
{
    public class TaskListDataTemplateSelector : DataTemplateSelector
    {
        public override DataTemplate
            SelectTemplate(object item, DependencyObject container)
        {
            FrameworkElement element = container as FrameworkElement;

            if (element != null && item != null && item is Task)
            {
                Task taskitem = item as Task;

                if (taskitem.Priority == 1)
                    return
                        element.FindResource("importantTaskTemplate") as DataTemplate;
                else
                    return
                        element.FindResource("myTaskTemplate") as DataTemplate;
            }

            return null;
        }
    }
}

Namespace SDKSample
    Public Class TaskListDataTemplateSelector
        Inherits DataTemplateSelector
        Public Overrides Function SelectTemplate(ByVal item As Object, ByVal container As DependencyObject) As DataTemplate

            Dim element As FrameworkElement
            element = TryCast(container, FrameworkElement)

            If element IsNot Nothing AndAlso item IsNot Nothing AndAlso TypeOf item Is Task Then

                Dim taskitem As Task = TryCast(item, Task)

                If taskitem.Priority = 1 Then
                    Return TryCast(element.FindResource("importantTaskTemplate"), DataTemplate)
                Else
                    Return TryCast(element.FindResource("myTaskTemplate"), DataTemplate)
                End If
            End If

            Return Nothing
        End Function
    End Class
End Namespace

Wir können dann den TaskListDataTemplateSelector als Ressource deklarieren:We can then declare the TaskListDataTemplateSelector as a resource:

<Window.Resources>
<local:TaskListDataTemplateSelector x:Key="myDataTemplateSelector"/>
</Window.Resources>

Um die Vorlagen Auswahl Ressource zu verwenden, weisen Sie Sie der ItemTemplateSelector-Eigenschaft des ListBoxzu.To use the template selector resource, assign it to the ItemTemplateSelector property of the ListBox. Der ListBox Ruft die SelectTemplate-Methode der TaskListDataTemplateSelector für jedes der Elemente in der zugrunde liegenden Auflistung auf.The ListBox calls the SelectTemplate method of the TaskListDataTemplateSelector for each of the items in the underlying collection. Beim Aufruf wird das Datenobjekt als Elementparameter übergeben.The call passes the data object as the item parameter. Der DataTemplate, der von der-Methode zurückgegeben wird, wird dann auf das Datenobjekt angewendet.The DataTemplate that is returned by the method is then applied to that data object.

<ListBox Width="400" Margin="10"
         ItemsSource="{Binding Source={StaticResource myTodoList}}"
         ItemTemplateSelector="{StaticResource myDataTemplateSelector}"
         HorizontalContentAlignment="Stretch"/>

Das vollständige Beispiel finden Sie unter Einführung in das Datenvorlagenbeispiel.For the complete sample, see Introduction to Data Templating Sample.

Hinweise

In der Regel erstellen Sie eine DataTemplateSelector, wenn mehrere DataTemplate für denselben Objekttyp vorhanden sind und Sie Ihre eigene Logik zum Auswählen eines DataTemplate bereitstellen möchten, das auf der Grundlage der Eigenschaften der einzelnen Datenobjekte angewendet werden soll.Typically, you create a DataTemplateSelector when you have more than one DataTemplate for the same type of objects and you want to supply your own logic to choose a DataTemplate to apply based on the properties of each data object. Beachten Sie, dass Sie die DataType-Eigenschaft für die DataTemplatefestlegen können, wenn Sie über Objekte unterschiedlicher Typen verfügen.Note that if you have objects of different types you can set the DataType property on the DataTemplate. Wenn Sie dies tun, müssen Sie keine DataTemplateSelectorerstellen.If you do that then there is no need to create a DataTemplateSelector. Wenn Sie über Objekte desselben Typs, aber mit unterschiedlichen Eigenschaften verfügen, können Sie auch die Verwendung einer DataTrigger oder eines Daten Konverters in Erwägung gezogen.Furthermore, if you have objects of the same type but with different properties, you can also consider using a DataTrigger or a data converter. Weitere Informationen finden Sie unter Übersicht über Datenvorlagen.For more information, see Data Templating Overview.

Erstellen Sie eine-Klasse, die von DataTemplateSelector erbt, und überschreiben Sie die SelectTemplate-Methode, um eine Vorlagen Auswahl zu erstellen.To create a template selector, create a class that inherits from DataTemplateSelector and override the SelectTemplate method. Nachdem die Klasse definiert wurde, können Sie der Vorlagen Auswahl Eigenschaft des Elements eine Instanz der-Klasse zuweisen.Once your class is defined you can assign an instance of the class to the template selector property of your element.

Konstruktoren

DataTemplateSelector()

Initialisiert eine neue Instanz der Klasse DataTemplateSelector.Initializes a new instance of the DataTemplateSelector class.

Methoden

Equals(Object)

Bestimmt, ob das angegebene Objekt gleich dem aktuellen Objekt ist.Determines whether the specified object is equal to the current object.

(Geerbt von Object)
GetHashCode()

Dient als die Standard-HashfunktionServes as the default hash function.

(Geerbt von Object)
GetType()

Ruft den Type der aktuellen Instanz ab.Gets the Type of the current instance.

(Geerbt von Object)
MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.Creates a shallow copy of the current Object.

(Geerbt von Object)
SelectTemplate(Object, DependencyObject)

Gibt beim Überschreiben in einer abgeleiteten Klasse eine auf benutzerdefinierter Logik basierende DataTemplate zurück.When overridden in a derived class, returns a DataTemplate based on custom logic.

ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.Returns a string that represents the current object.

(Geerbt von Object)

Gilt für: