Procedura: rendere i dati disponibili per l'associazione in XAML

Questo argomento illustra diversi modi in cui è possibile rendere disponibili i dati per l'associazione in Xaml (Extensible Application Markup Language), a seconda delle esigenze dell'applicazione.

Esempio

Se si dispone di un oggetto CLR (Common Language Runtime) a cui si vuole eseguire il binding da XAML, un modo per rendere l'oggetto disponibile per l'associazione consiste nel definirlo come risorsa e assegnargli un oggetto x:Key. Nell'esempio seguente si dispone di un Person oggetto con una proprietà stringa denominata PersonName. L'oggetto Person (nella riga evidenziata che contiene l'elemento <src> ) è definito nello spazio dei nomi denominato SDKSample.

<Window
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:src="clr-namespace:SDKSample"
  SizeToContent="WidthAndHeight"
  Title="Simple Data Binding Sample">

  <Window.Resources>
    <src:Person x:Key="myDataSource" PersonName="Joe"/>
    <Style TargetType="{x:Type Label}">
      <Setter Property="DockPanel.Dock" Value="Top"/>
      <Setter Property="FontSize" Value="12"/>
    </Style>
    <Style TargetType="{x:Type TextBox}">
      <Setter Property="Width" Value="100"/>
      <Setter Property="Height" Value="25"/>
      <Setter Property="DockPanel.Dock" Value="Top"/>
    </Style>
    <Style TargetType="{x:Type TextBlock}">
      <Setter Property="Width" Value="100"/>
      <Setter Property="Height" Value="25"/>
      <Setter Property="DockPanel.Dock" Value="Top"/>
      <Setter Property="Padding" Value="3"/>
    </Style>
  </Window.Resources>
  <Border Margin="5" BorderBrush="Aqua" BorderThickness="1" Padding="8" CornerRadius="3">
    <DockPanel Width="200" Height="100" Margin="35">
      <Label>Enter a Name:</Label>
      <TextBox>
        <TextBox.Text>
          <Binding Source="{StaticResource myDataSource}" Path="PersonName"
                   UpdateSourceTrigger="PropertyChanged"/>
        </TextBox.Text>
      </TextBox>
      
      <Label>The name you entered:</Label>
      <TextBlock Text="{Binding Source={StaticResource myDataSource}, Path=PersonName}"/>
    </DockPanel>
  </Border>
</Window>

È quindi possibile associare il TextBlock controllo all'oggetto in XAML, come la riga evidenziata che contiene l'elemento <TextBlock> visualizzato.

In alternativa, è possibile usare la ObjectDataProvider classe , come nell'esempio seguente:

<Window
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:src="clr-namespace:SDKSample"
  xmlns:system="clr-namespace:System;assembly=mscorlib"
  SizeToContent="WidthAndHeight"
  Title="Simple Data Binding Sample">

  <Window.Resources>
    <ObjectDataProvider x:Key="myDataSource" ObjectType="{x:Type src:Person}">
      <ObjectDataProvider.ConstructorParameters>
        <system:String>Joe</system:String>
      </ObjectDataProvider.ConstructorParameters>
    </ObjectDataProvider>
    <Style TargetType="{x:Type Label}">
      <Setter Property="DockPanel.Dock" Value="Top"/>
      <Setter Property="FontSize" Value="12"/>
    </Style>
    <Style TargetType="{x:Type TextBox}">
      <Setter Property="Width" Value="100"/>
      <Setter Property="Height" Value="25"/>
      <Setter Property="DockPanel.Dock" Value="Top"/>
    </Style>
    <Style TargetType="{x:Type TextBlock}">
      <Setter Property="Width" Value="100"/>
      <Setter Property="Height" Value="25"/>
      <Setter Property="DockPanel.Dock" Value="Top"/>
    </Style>
  </Window.Resources>

  <Border Margin="25" BorderBrush="Aqua" BorderThickness="3" Padding="8">
    <DockPanel Width="200" Height="100">
      <Label>Enter a Name:</Label>
      <TextBox>
        <TextBox.Text>
          <Binding Source="{StaticResource myDataSource}" Path="Name"
                   UpdateSourceTrigger="PropertyChanged"/>
        </TextBox.Text>
      </TextBox>

      <Label>The name you entered:</Label>
      <TextBlock Text="{Binding Source={StaticResource myDataSource}, Path=Name}"/>
    </DockPanel>
  </Border>
</Window>

Si definisce l'associazione allo stesso modo, come la riga evidenziata che contiene l'elemento <TextBlock> visualizzato.

In questo particolare esempio, il risultato è lo stesso: si dispone di un TextBlock oggetto con il contenuto Joedi testo . Tuttavia, la ObjectDataProvider classe fornisce funzionalità come la possibilità di eseguire l'associazione al risultato di un metodo. È possibile scegliere di usare la ObjectDataProvider classe se è necessaria la funzionalità fornita.

Tuttavia, se si esegue il binding a un oggetto che è già stato creato, è necessario impostare DataContext nel codice, come nell'esempio seguente.

DataSet myDataSet;

private void OnInit(object sender, EventArgs e)
{
  string mdbFile = Path.Combine(AppDataPath, "BookData.mdb");
  string connString = string.Format(
      "Provider=Microsoft.Jet.OLEDB.4.0; Data Source={0}", mdbFile);
  OleDbConnection conn = new OleDbConnection(connString);
  OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM BookTable;", conn);

  myDataSet = new DataSet();
  adapter.Fill(myDataSet, "BookTable");

  // myListBox is a ListBox control.
  // Set the DataContext of the ListBox to myDataSet
  myListBox.DataContext = myDataSet;
}
Private myDataSet As DataSet

Private Sub OnInit(ByVal sender As Object, ByVal e As EventArgs)
  Dim mdbFile As String = Path.Combine(AppDataPath, "BookData.mdb")
  Dim connString As String = String.Format("Provider=Microsoft.Jet.OLEDB.4.0; Data Source={0}", mdbFile)
  Dim conn As New OleDbConnection(connString)
  Dim adapter As New OleDbDataAdapter("SELECT * FROM BookTable;", conn)

  myDataSet = New DataSet()
  adapter.Fill(myDataSet, "BookTable")

  ' myListBox is a ListBox control.
  ' Set the DataContext of the ListBox to myDataSet
  myListBox.DataContext = myDataSet
End Sub

Per accedere ai dati XML per l'associazione tramite la classe , vedere Eseguire l'associazione XmlDataProvider a dati XML tramite query XMLDataProvider e XPath. Per accedere ai dati XML per l'associazione tramite la classe , vedere Eseguire l'associazione ObjectDataProvider a XDocument, XElement o LINQ per i risultati delle query XML.

Per informazioni su molti modi in cui è possibile specificare i dati a cui si sta eseguendo l'associazione, vedere Specificare l'origine di associazione. Per informazioni sui tipi di dati a cui è possibile eseguire l'associazione o su come implementare oggetti CLR (Common Language Runtime) personalizzati per l'associazione, vedere Cenni preliminari sulle origini di binding.

Vedi anche