Почему это представление некорректно привязано к этой ViewModel?

StackOverflow https://stackoverflow.com/questions/802162

Вопрос

Я пытаюсь привязать свое представление к моей модели представления без DataObjectProvider.

Тот Самый следующий код выполняется без ошибок, но мой список - это пустой.

Насколько я могу судить, я правильно:

  • установите DataContext представления в саму ViewModel (DataContext = new CustomersViewModel();)
  • предоставьте доступ к объектам customer в ViewModel (public static ObservableCollection<Customer> GetAll())
  • привяжите ListBox к объектам клиента (ItemsSource="{Binding GetAll}")

Какой маленький фрагмент синтаксиса я здесь упускаю?

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();
        }
    }
}

Клиент.cs: (модель)

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;
        }

    }
}
Это было полезно?

Решение

Проблема в том, что вы пытаетесь выполнить привязку к CustomerViewModel .GetAll(), когда GetAll в CustomerViewModel является статической функцией, а не свойством экземпляра.

Измените статическую функцию на что-то вроде этого (в CustomerViewModel):

public ObservableCollection<Customer> GetAll
{
    get { return Customer.GetAll(); }
}

Другие советы

Проблема в том, что CustomersViewModel .GetAll() это статический метод.Привязка работает только со свойствами экземпляра.Вам следует перенести реализацию GetAll() в конструктор, а затем предоставить коллекцию как свойство экземпляра класса.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top