Perché questa vista non è correttamente vincolante per questo ViewModel?
-
03-07-2019 - |
Domanda
Sto cercando di associare la mia vista al mio modello di vista senza DataObjectProvider.
Il codice seguente viene eseguito senza errori , ma il mio ListBox è vuoto .
Per quanto ne so, ho correttamente:
- imposta il DataContext di View sul ViewModel stesso (
DataContext = new CustomersViewModel ();
) - espone gli oggetti cliente in ViewModel (
OsservableCollection statico pubblico < Customer > GetAll ()
) - associa ListBox agli oggetti cliente (
ItemsSource = " {Binding GetAll} "
)
Quale piccola parte della sintassi mi manca qui?
CustomersView.xaml:
<UserControl x:Class="TestDynamicForm123.View.CustomersView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<UserControl.Resources>
<Style x:Key="allCustomersListBox" TargetType="ListBox">
<Setter Property="BorderThickness" Value="0"/>
</Style>
<DataTemplate x:Key="allCustomersDataTemplate">
<StackPanel Orientation="Horizontal">
<TextBlock Text="{Binding FirstName}"/>
<TextBlock Text=" "/>
<TextBlock Text="{Binding LastName}"/>
</StackPanel>
</DataTemplate>
</UserControl.Resources>
<StackPanel Style="{StaticResource viewWrappingStackPanel}">
<ListBox ItemsSource="{Binding GetAll}"
ItemTemplate="{StaticResource allCustomersDataTemplate}"
Style="{StaticResource allCustomersListBox}">
</ListBox>
</StackPanel>
</UserControl>
CustomersView.xaml.cs:
using System.Windows.Controls;
using TestDynamicForm123.ViewModel;
namespace TestDynamicForm123.View
{
public partial class CustomersView : UserControl
{
public CustomersView()
{
InitializeComponent();
DataContext = new CustomersViewModel();
}
}
}
CustomersViewModel.cs:
using System.Collections.ObjectModel;
namespace TestDynamicForm123.ViewModel
{
public class CustomersViewModel
{
public static ObservableCollection<Customer> GetAll()
{
return Customer.GetAll();
}
}
}
Customer.cs: (modello)
using System.Collections.ObjectModel;
namespace TestDynamicForm123.ViewModel
{
public class Customer
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public int Age { get; set; }
public static ObservableCollection<Customer> GetAll()
{
ObservableCollection<Customer> customers = new ObservableCollection<Customer>();
customers.Add(new Customer() { FirstName = "Jay", LastName = "Anders", Age = 34 });
customers.Add(new Customer() { FirstName = "Jim", LastName = "Smith", Age = 23 });
customers.Add(new Customer() { FirstName = "John", LastName = "Jones", Age = 22 });
customers.Add(new Customer() { FirstName = "Sue", LastName = "Anders", Age = 21 });
customers.Add(new Customer() { FirstName = "Chet", LastName = "Rogers", Age = 35 });
customers.Add(new Customer() { FirstName = "James", LastName = "Anders", Age = 37 });
return customers;
}
}
}
Soluzione
Il problema è che stai tentando di associare CustomerViewModel.GetAll (), quando GetAll in CustomerViewModel è una funzione statica e non una proprietà di istanza.
Cambia la funzione statica in qualcosa del genere (in CustomerViewModel):
public ObservableCollection<Customer> GetAll
{
get { return Customer.GetAll(); }
}
Altri suggerimenti
Il problema è che CustomersViewModel
.GetAll ()
è un metodo statico. Il bind funziona solo con le proprietà dell'istanza. È necessario spostare l'implementazione di GetAll ()
nel costruttore, quindi esporre la raccolta come proprietà dell'istanza della classe.