Как мне использовать DomainContext.Load для заполнения свойств моей ViewModel?

У меня есть страница 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. (Точка останова в моем репозитории показывает, что код для заполнения коллекции выполняется, но только после рендеринга страницы.)

Кто-нибудь может показать мне, как это сделать?


person kristian    schedule 18.06.2010    source источник


Ответы (1)


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

Моя обновленная 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");
            }
        }
    }
}

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

person kristian    schedule 21.06.2010