Как я могу использовать DomainContext.Load, чтобы заполнить свойства моей ViewModel? - PullRequest
7 голосов
/ 18 июня 2010

У меня есть страница Silverlight, которая получает данные из класса модели представления, который объединяет некоторые данные из различных доменных служб (служб RIA).

В идеале я бы хотел, чтобы страница могла связывать данные.управляет свойствами объекта модели представления, но поскольку DomainContext.Load выполняет запрос асинхронно, данные не доступны при загрузке страницы.

Моя страница Silverlight имеет следующий XAML:

<navigation:Page x:Class="Demo.UI.Pages.WidgetPage" 
               // the usual xmlns stuff here...
               xmlns:local="clr-namespace:Demo.UI.Pages" mc:Ignorable="d"
               xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"

                d:DataContext="{d:DesignInstance Type=local:WidgetPageModel, IsDesignTimeCreatable=False}"

               d:DesignWidth="640" d:DesignHeight="480"
               Title="Widget Page">
        <Canvas x:Name="LayoutRoot">
            <ListBox ItemsSource="{Binding RedWidgets}" Width="150" Height="500" />
        </Canvas>
    </navigation:Page>

Моя ViewModel выглядит следующим образом:

public class WidgetPageModel
{
    private WidgetDomainContext WidgetContext { get; set; }

    public WidgetPageModel()
    {          
        this.WidgetContext = new WidgetDomainContext();

        WidgetContext.Load(WidgetContext.GetAllWidgetsQuery(), false);            

    }

    public IEnumerable<Widget> RedWidgets
    {
        get
        {
            return this.WidgetContext.Widgets.Where(w => w.Colour == "Red");
        }
    }
}

Я думаю, что этот подход должен быть в корне неверным, поскольку асинхронная природа Load означает, что список виджетов не обязательно заполняется при привязке данных ListBox.(Точка останова в моем хранилище показывает, что код для заполнения в коллекции выполняется, но только после визуализации страницы.)

Может кто-нибудь показать мне правильный способ сделать это?

1 Ответ

4 голосов
/ 21 июня 2010

Недостающая часть головоломки состоит в том, что мне нужно было поднимать события, когда свойства менялись.

Моя обновленная ViewModel выглядит следующим образом:

public class WidgetPageModel : INotifyPropertyChanged
{

    public event PropertyChangedEventHandler PropertyChanged;

    protected void RaisePropertyChanged(string propertyName)
    {
        if (PropertyChanged != null)
        {
            PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }
    }

    private WidgetDomainContext WidgetContext { get; set; }

    public WidgetPageModel()
    {          
        this.WidgetContext = new WidgetDomainContext();

        WidgetContext.Load(WidgetContext.GetAllWidgetsQuery(), 
            (result) =>
            {
                this.RedWidgets = this.WidgetContext.Widgets.Where(w => w.Colour == "Red");
            }, null);            

    }

    private IEnumerable<Widget> _redWidgets;
    public IEnumerable<Widget> RedWidgets
    {
        get
        {
            return _redWidgets;
        }
        set
        {
            if(value != _redWidgets)
            {
                _redWidgets = value;
                RaisePropertyChanged("RedWidgets");
            }
        }
    }
}

Элементы управления, связанные с этими свойствами, обновляются при возникновении события изменения свойства.

...