如何深入分析prism journal导航按钮的可用性,探索其优化策略?

2026-04-11 12:171阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计346个文字,预计阅读时间需要2分钟。

如何深入分析prism journal导航按钮的可用性,探索其优化策略?

使用Prism导航功能时,跳转多个视图,记录一下:

1. 导航记录的产生:在区域导航过程中产生。

2.代码示例:`_regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back={ journal });`

prism使用导航功能的时候,跳了几个坑,记录一下。

1、导航记录的产生,是在区域导航过程中产生的。

  

如何深入分析prism journal导航按钮的可用性,探索其优化策略?

_regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back =>
{
journal= back.Context.NavigationService.Journal;

journalHistory();
});

2、通过journal.goback(),journal.goforward()来向前向后。

3、journal.CanGoback和Canforward来确定是否可导。

4、但是如果在命令中使用GobackCommand=new DelegateCommand(Goback,()=>journal.CanGoBack)话就不可以,因为这时候journal还是null。

5、测试成功的方法

private IRegionNavigationJournal journal; public MainWindowViewModel(IRegionManager regionManager) { _regionManager = regionManager; CreateMenuBar(); NavigateCommand = new DelegateCommand<MenuBar>(Navigate); GoBackCommand = new DelegateCommand(goback).ObservesCanExecute(() => CanGoBack); GoForwardCommand = new DelegateCommand(goforward).ObservesCanExecute(() => CanGoForward); } private void goforward() { journal.GoForward(); journalHistory(); } private void goback() { journal.GoBack(); journalHistory(); } private void Navigate(MenuBar obj) { if (obj == null || string.IsNullOrEmpty(obj.NameSpace)) return; _regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back => { journal= back.Context.NavigationService.Journal; journalHistory(); }); } private void journalHistory() { CanGoForward = journal.CanGoForward; CanGoBack = journal.CanGoBack; }

  因为CanGoBack在运行过程中不停变化,需要在每一次记录中都要作好记录。同时,如果CanExecute要体现在UI同步更新中,需要使用ObserversCanExecute方法。

因为向前向后也是有限的,走到头就不能向前走了,所以需要不断更新。

本文共计346个文字,预计阅读时间需要2分钟。

如何深入分析prism journal导航按钮的可用性,探索其优化策略?

使用Prism导航功能时,跳转多个视图,记录一下:

1. 导航记录的产生:在区域导航过程中产生。

2.代码示例:`_regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back={ journal });`

prism使用导航功能的时候,跳了几个坑,记录一下。

1、导航记录的产生,是在区域导航过程中产生的。

  

如何深入分析prism journal导航按钮的可用性,探索其优化策略?

_regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back =>
{
journal= back.Context.NavigationService.Journal;

journalHistory();
});

2、通过journal.goback(),journal.goforward()来向前向后。

3、journal.CanGoback和Canforward来确定是否可导。

4、但是如果在命令中使用GobackCommand=new DelegateCommand(Goback,()=>journal.CanGoBack)话就不可以,因为这时候journal还是null。

5、测试成功的方法

private IRegionNavigationJournal journal; public MainWindowViewModel(IRegionManager regionManager) { _regionManager = regionManager; CreateMenuBar(); NavigateCommand = new DelegateCommand<MenuBar>(Navigate); GoBackCommand = new DelegateCommand(goback).ObservesCanExecute(() => CanGoBack); GoForwardCommand = new DelegateCommand(goforward).ObservesCanExecute(() => CanGoForward); } private void goforward() { journal.GoForward(); journalHistory(); } private void goback() { journal.GoBack(); journalHistory(); } private void Navigate(MenuBar obj) { if (obj == null || string.IsNullOrEmpty(obj.NameSpace)) return; _regionManager.Regions[PrismManager.MainViewRegionName].RequestNavigate(obj.NameSpace, back => { journal= back.Context.NavigationService.Journal; journalHistory(); }); } private void journalHistory() { CanGoForward = journal.CanGoForward; CanGoBack = journal.CanGoBack; }

  因为CanGoBack在运行过程中不停变化,需要在每一次记录中都要作好记录。同时,如果CanExecute要体现在UI同步更新中,需要使用ObserversCanExecute方法。

因为向前向后也是有限的,走到头就不能向前走了,所以需要不断更新。