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 die Bindungsquelle ist eine Liste von Task Objekte.In this example, the binding source is a list of Task objects. Eine der Eigenschaften von einem Task Objekt Priority.One of the properties of a Task object is Priority. Es gibt zwei Datenvorlagen definiert, myTaskTemplate und importantTaskTemplate.There are two data templates defined, myTaskTemplate and importantTaskTemplate.

Bereitstellen von Logik zum Auswählen der DataTemplate auf der Grundlage der Priority Wert des Datenobjekts, erstellen Sie eine Unterklasse von DataTemplateSelector und überschreiben die SelectTemplate Methode.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 die SelectTemplate Methode stellt die Logik zum Zurückgeben der entsprechenden Vorlage basierend auf den Wert der Priority Eigenschaft.In the following example, the SelectTemplate method provides logic to return the appropriate template based on the value of the Priority property. Die Vorlage, die zurückgegeben wurde gefunden, in den Ressourcen des umschließenden Window Element.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 Vorlagenauswahlressource verwenden zu können, weisen Sie ihn der ItemTemplateSelector Eigenschaft der ListBox.To use the template selector resource, assign it to the ItemTemplateSelector property of the ListBox. Die ListBox Aufrufe der SelectTemplate Methode der TaskListDataTemplateSelector für jedes der Elemente in der zugrunde liegenden Auflistung.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. Die DataTemplate das zurückgegeben wird, indem die Methode wird dann auf die betreffende 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

Normalerweise erstellen Sie eine DataTemplateSelector , wenn Sie haben mehr als eine DataTemplate für den gleichen Typ von Objekten, und Sie Ihre eigene Logik zum Auswählen angeben möchten einer DataTemplate anwenden auf Grundlage der Eigenschaften der einzelnen Datenobjekte.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, die Ihnen bei Objekte unterschiedlicher Typen festgelegt können die DataType Eigenschaft für die DataTemplate.Note that if you have objects of different types you can set the DataType property on the DataTemplate. Wenn dies der Fall, die besteht keine Notwendigkeit zum Erstellen einer DataTemplateSelector.If you do that then there is no need to create a DataTemplateSelector. Darüber hinaus, wenn Sie Objekte des gleichen Typs jedoch unterschiedliche Eigenschaften verfügen, Sie haben auch die Möglichkeit mit einem DataTrigger oder eines Datenkonverters.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.

Um eine Vorlagenauswahl zu erstellen, erstellen Sie eine Klasse, die von erbt DataTemplateSelector und überschreiben die SelectTemplate Methode.To create a template selector, create a class that inherits from DataTemplateSelector and override the SelectTemplate method. Wenn Ihre Klasse definiert ist, können Sie eine Instanz der Klasse, die die Template-Selektor-Eigenschaft Ihres Elements 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: