DataTemplateSelector DataTemplateSelector DataTemplateSelector DataTemplateSelector Class

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
DataTemplateSelectorDataTemplateSelectorDataTemplateSelectorDataTemplateSelector

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. PriorityOne 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 DataTemplate DataTemplateSelector , und überschreiben Sie Priority die SelectTemplate -Methode, um zu bestimmen, welche Logik basierend auf dem 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 Priority der-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>

Wenn Sie die Vorlagen Auswahl Ressource verwenden möchten, weisen Sie ItemTemplateSelector Sie der- ListBoxEigenschaft von zu.To use the template selector resource, assign it to the ItemTemplateSelector property of the ListBox. Die 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 DataTemplateSelector einen, wenn Sie mehr als DataTemplate einen für denselben Objekttyp haben, und Sie möchten eine eigene Logik bereitstellen DataTemplate , um eine für die Anwendung basierend auf den Eigenschaften der einzelnen Datenobjekte auszuwählen.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 DataTemplateim festlegen können, wenn Sie über Objekte mit unterschiedlichen 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, ist es nicht erforderlich, eine DataTemplateSelectorzu erstellen.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 eines DataTrigger -oder-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() DataTemplateSelector() DataTemplateSelector() DataTemplateSelector()

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

Methoden

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

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

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Fungiert als Standardhashfunktion.Serves as the default hash function.

(Inherited from Object)
GetType() GetType() GetType() GetType()

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

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

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

(Inherited from Object)
SelectTemplate(Object, DependencyObject) SelectTemplate(Object, DependencyObject) SelectTemplate(Object, DependencyObject) 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() ToString() ToString() ToString()

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

(Inherited from Object)

Gilt für: