Procedura: Ordinare e raggruppare dati tramite una visualizzazione in XAMLHow to: Sort and Group Data Using a View in XAML

Questo esempio illustra come creare una visualizzazione di una raccolta di dati in Extensible Application Markup Language (XAML)Extensible Application Markup Language (XAML).This example shows how to create a view of a data collection in Extensible Application Markup Language (XAML)Extensible Application Markup Language (XAML). Le viste consentono per le funzionalità di raggruppamento, ordinamento, filtro e la nozione di elemento corrente.Views allow for the functionalities of grouping, sorting, filtering, and the notion of a current item.

EsempioExample

Nell'esempio seguente, la risorsa statica denominata inserisce viene definito come una raccolta di luogo oggetti, in cui ogni luogo oggetto è costituito da un nome di città e il stato.In the following example, the static resource named places is defined as a collection of Place objects, in which each Place object is consisted of a city name and the state. Il prefisso src viene eseguito il mapping allo spazio dei nomi in cui l'origine dati posizioni è definito.The prefix src is mapped to the namespace where the data source Places is defined. Il prefisso scm esegue il mapping ai "clr-namespace:System.ComponentModel;assembly=WindowsBase" e dat esegue il mapping a "clr-namespace:System.Windows.Data;assembly=PresentationFramework".The prefix scm maps to "clr-namespace:System.ComponentModel;assembly=WindowsBase" and dat maps to "clr-namespace:System.Windows.Data;assembly=PresentationFramework".

L'esempio seguente crea una visualizzazione della raccolta di dati ordinati in base al nome della città e raggruppata per stato.The following example creates a view of the data collection that is sorted by the city name and grouped by the state.

<Window.Resources>

  <src:Places x:Key="places"/>

  <CollectionViewSource Source="{StaticResource places}" x:Key="cvs">
    <CollectionViewSource.SortDescriptions>
      <scm:SortDescription PropertyName="CityName"/>
    </CollectionViewSource.SortDescriptions>
    <CollectionViewSource.GroupDescriptions>
      <dat:PropertyGroupDescription PropertyName="State"/>
    </CollectionViewSource.GroupDescriptions>
  </CollectionViewSource>

La vista può essere quindi un'origine di associazione, come nell'esempio seguente:The view can then be a binding source, as in the following example:

<ListBox ItemsSource="{Binding Source={StaticResource cvs}}"
         DisplayMemberPath="CityName" Name="lb">
  <ListBox.GroupStyle>
    <x:Static Member="GroupStyle.Default"/>
  </ListBox.GroupStyle>
</ListBox>

Per le associazioni ai dati XML definiti in un XmlDataProvider risorsa, far precedere il nome XML con un simbolo @.For bindings to XML data defined in an XmlDataProvider resource, precede the XML name with an @ symbol.

<XmlDataProvider x:Key="myTasks" XPath="Tasks/Task">
    <x:XData>
        <Tasks xmlns="">
            <Task Name="Groceries" Priority="2" Type="Home">
<CollectionViewSource x:Key="mySortedTasks"
                      Source="{StaticResource myTasks}">
    <CollectionViewSource.SortDescriptions>
        <scm:SortDescription PropertyName="@Priority" />
    </CollectionViewSource.SortDescriptions>
    <CollectionViewSource.GroupDescriptions>
        <dat:PropertyGroupDescription PropertyName="@Priority" />
    </CollectionViewSource.GroupDescriptions>
</CollectionViewSource>

Vedere ancheSee also