正如我最近了解到的,哪个 ViewModel 是“活动的”取决于heavily您使用的 Presenter 上。如果您只使用默认的演示者,这似乎很容易,因为在任何给定时间只显示一个 ViewModel。但是,使用更高级的演示者,您可以拥有多个活动 ViewModel。
由于当前活动的 ViewModel 取决于您正在使用的 Presenter(位于视图层),因此 Mvx 核心无法知道如何访问它/它们。如果这是您认为需要的东西,我建议您使用自己的界面实现自己的 Presenter。
这是 iOS 的示例:
ICurrentViewModelPresenter.cs
public interface ICurrentViewModelPresenter
{
IMvxViewModel CurrentViewModel { get; }
}
当前ViewModelPresenter.cs:
public class CurrentViewModelPresenter : MvxTouchViewPresenter, ICurrentViewModelPresenter
{
public CurrentViewModelPresenter(UIApplicationDelegate del, UIWindow win)
: base(del, win)
{
}
public IMvxViewModel CurrentViewModel
{
get
{
var viewController = MasterNavigationController.TopViewController;
if (viewController == null) return null;
var touchView = viewController as IMvxTouchView;
if (touchView == null) return null;
return touchView.ReflectionGetViewModel();
}
}
}
安装程序.cs:
public class Setup : MvxTouchSetup
{
private readonly MvxApplicationDelegate _del;
private readonly UIWindow _win;
public Setup(MvxApplicationDelegate del, UIWindow win)
: base(del, win)
{
_del = del;
_win = win;
}
...
protected override IMvxTouchViewPresenter CreatePresenter()
{
var presenter = new CurrentViewModelPresenter(_del, _win);
Mvx.RegisterSingleton<ICurrentViewModelPresenter>(presenter);
return presenter;
}
}
代码中的任何位置:
var presenter = Mvx.Resolve<ICurrentViewModelPresenter>(); // or inject with IoC
var current = presenter.CurrentViewModel;
请注意,这些都没有经过测试,但它应该让您了解它是如何工作的。