#mvvm #datacontext #avalondock
#mvvm #datacontext #avalondock
Вопрос:
Использование avalondock кажется довольно сложным в среде MVVM. Как только я отсоединяю DocumentPane от shellview, я теряю соответствующий datacontext и мое представление становится пустым. При повторном подключении все возвращается в нормальное состояние.
Есть ли у кого-нибудь решение?
Комментарии:
1. Пожалуйста, взгляните сюда в документации AvalonDock.
2. Я написал статью, которая демонстрирует один из способов интеграции AvalonDock в приложение MVVM: codeproject.com/Articles/239342/AvalonDock-and-MVVM
Ответ №1:
Вот что я использую в настоящее время; в моем приложении есть пара закрепляемых панелей, каждая из которых имеет свою собственную viewmodel. Эти viewmodels отображаются как свойства из viewmodel главного окна, которое также является DataContext главного окна. Хитрость заключается в том, чтобы ссылаться на этот datacontext с помощью статического приложения.Главное окно текущего экземпляра.DataContext.
Например:
class MainWindowViewModel
{
public WindowAViewModel {get; set;}
public WindowBViewModel {get; set;}
}
//this goes in App.xaml.cs, because my MainWindowViewModel has a constructor
//with arguments, else you could just set the Window.DataContext in xaml
var window = new MainWindow();
window.DataContext = new MainWindowViewModel( ... );
xaml в MainWindow:
<ad:DockingManager>
<ad:ResizingPanel Orientation="Horizontal" >
<ad:DockablePane>
<ad:DockableContent>
<l:WindowA DataContext="{Binding Path=MainWindow.DataContext.WindowAViewModel,
Source={x:Static app:App.Current}}"/>
</ad:DockableContent>
<ad:DockableContent>
<l:WindowB DataContext="{Binding Path=MainWindow.DataContext.WindowBViewModel,
Source={x:Static app:App.Current}}"/>
</ad:DockableContent>
</ad:DockablePane>
</ad:ResizingPanel>
</ad:DockingManager>
Не уверен, как это работает для больших модульных приложений, но я видел пример приложения в Prism, используемого с Sofa (оболочкой AvalonDock), поэтому вы, возможно, захотите проверить, как они это сделали.