silverlight开发实例(Prism+MVVM+RIA)(三)--创建页面导航

在实现了页面登陆后,下面接着就是关于相应用户操作了!

首先在此项目中Shell页定义了两个Region区域,一个NavRegion导航区域,一个MainContentRegion内容区域。导航区域是为了能够快速在视图间切换,内容区域自然是操作的界面了。


如图,下方是各模块的导航,在点击模块后会加载该模块对应的功能菜单。在上图右上角加入了两个导航按钮,分别为“上一项”,“下一项”用来切换视图。

导航的实现:

1、首先目前还没有添加其他模块仅还在Shell模块下进行测试,测试时加入的视图能够正确导航,至于新增模块是否可以导航,今后再进一步测试。

2、注册模块需要在内容页上加载的视图,此例是在完成用户登录后开始注册视图,如果是在模块中注册可以再模块初始化函数中注册即可。

[ImportingConstructor]
        public ShellViewModel(IEventAggregator _eventAggregator, IRegionManager _regionManager,ModuleService _moduleService)
        {
            eventAggregator = _eventAggregator;
            regionManager = _regionManager;
            this.eventAggregator.GetEvent<CommandEvent>().Subscribe(OnLoginComplete, ThreadOption.UIThread, true, p => p.CommandName == "LoginSucceed");
            _moduleService.GetModuleListQueryComplete += new EventHandler<EntityResultsArgs<T_SYS_MODULE>>(_moduleService_GetModuleListQueryComplete);
            _moduleService.GetModuleListAsync();
            
        }

 void OnLoginComplete(CommandEventPara para)
        {
            if (para.Entity is Exception)
            {

            }
            else
            {
                if (this.regionManager.Regions[RegionNames.NavRegion].GetView("NavView") == null)
                    this.regionManager.RegisterViewWithRegion(RegionNames.NavRegion, typeof(NavView)); ;
                if (this.regionManager.Regions[RegionNames.NavRegion].GetView("TestView") == null)
                    this.regionManager.RegisterViewWithRegion(RegionNames.MainContentRegion, typeof(TestView)); ;
                if (this.regionManager.Regions[RegionNames.MainContentRegion].GetView("ApplicationView") == null)
                    this.regionManager.RegisterViewWithRegion(RegionNames.MainContentRegion, typeof(ApplicationView));
                this.regionManager.RequestNavigate(RegionNames.NavRegion, "NavView");
                
            }
        }
3、菜单事件响应则是通过在事件绑定,将选择的菜单项传递给事件函数即可,另外如果有一些复杂参数也可通过事件参数进行传递。

private ICommand selectedchanged;
        public ICommand SelectedChanged
        {
            get
            {
                if (selectedchanged == null)
                {
                    selectedchanged = new DelegateCommand<T_SYS_APPLICATION>(OnAppSelectedChanged);
                }
                return selectedchanged;
            }
        }

 void OnAppSelectedChanged(T_SYS_APPLICATION selectedApp)
        {
            if (selectedApp != null && !string.IsNullOrEmpty(selectedApp.SURL))
            {
                
                this.regionManager.RequestNavigate(RegionNames.MainContentRegion, selectedApp.SURL);
                this.eventAggregator.GetEvent<CommandEvent>().Publish(new CommandEventPara() { CommandName = "ApplicationSelectedChanged", Entity = selectedApp });
            }
        }

此例中的CommandEvent,CommandEventPara是自定义的事件及事件参数类,此处需要注意在菜单项被切换时要发出消息以便让导航页知道页面发生了变化。

4、导航页ViewModel中定义两个属性用于说明是否可以向前、向后导航,同时定义导航事件。在此ViewModel的构造中加入页面变化的消息接收处理。

    [Export]
    public class NavViewModel:MyViewModelBase
    {
        [ImportingConstructor]
        public NavViewModel(IEventAggregator _eventAggregator, IRegionManager _regionManager)
        {
            eventAggregator = _eventAggregator;
            regionManager = _regionManager;
            
            this.MainRegion = regionManager.Regions[RegionNames.MainContentRegion];

            this.eventAggregator.GetEvent<CommandEvent>().Subscribe(OnPageChanged, ThreadOption.UIThread, true, p => p.CommandName == "ModuleChanged");
            this.eventAggregator.GetEvent<CommandEvent>().Subscribe(OnPageChanged, ThreadOption.UIThread, true, p => p.CommandName == "ApplicationSelectedChanged");

        }
        IRegion MainRegion;
        IEventAggregator eventAggregator;
        IRegionManager regionManager;

        #region 绑定属性
       
        public V_SYS_USERINFO CurrentUser
        {
            get
            {
                
                    return ServiceLocator.Current.GetInstance<UserAccessService>().CurrentUser;
              
            }
          
        }
        public bool CanGoBack
        {
            get
            {
                return this.MainRegion.NavigationService.Journal.CanGoBack;
            }
        }

        public bool CanGoForward
        {
            get
            {
                return this.MainRegion.NavigationService.Journal.CanGoForward;
            }
        }
        #endregion

        #region 私有方法
        void OnPageChanged(CommandEventPara para)
        {
            ResetNavigationButtonState();
        }
        void ResetNavigationButtonState()
        {
            RaisePropertyChanged(() => this.CanGoBack);
            RaisePropertyChanged(() => this.CanGoForward);
        }
        #endregion

        #region 绑定事件
        private ICommand toBack;
        public ICommand ToBack
        {
            get
            {
                if (toBack == null)
                {
                    toBack = new DelegateCommand(OnToBack);
                    
                }
                return toBack;
            }
        }
        void OnToBack()
        {
            this.MainRegion.NavigationService.Journal.GoBack();
            ResetNavigationButtonState();
        }

        private ICommand toForword;
        public ICommand ToForword
        {
            get
            {
                if (toForword == null)
                {
                    toForword = new DelegateCommand(OnToForword);

                }
                return toForword;
            }
        }
        void OnToForword()
        {
            this.MainRegion.NavigationService.Journal.GoForward();
            ResetNavigationButtonState();
        }
        #endregion

    }

将上面的CanGoBack和CanGoForward两个属性绑定到导航按钮的IsEnabled属性中,同时将ToBack、ToForword两个事件绑定到导航按钮的触发事件中。需要注意的是,只要页面发生变化要使用ResetNavigationButtonState及时刷新这两个属性。

通过以上办法基本能实现页面间的导航了!

写程序不累,做个界面把人折磨的,不会美工的悲哀。。。

待续。。。。。。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: WPF是一种基于XAML语言的用户界面开发框架,使开发人员能够轻松创建漂亮和高效的桌面应用程序。MVVM是一种模式,它在WPF应用程序中广泛使用,它提供了一种分离UI和业务逻辑的方式,从而简化了代码结构。Prism是一个开源框架,它基于MVVM模式和WPF框架,提供了一些技术和工具,使开发人员能够更轻松地构建复杂的WPF应用程序。 使用WPF MVVM Prism框架可以帮助开发人员提高应用程序的可维护性和可扩展性。通过MVVM开发人员可以创建一个适应各种应用程序场景的模型,并将其与UI分离。数据绑定和命令绑定使开发人员能够更轻松地将模型中的数据和逻辑与UI控件集成起来。Prism框架还提供了一些工具和功能,如模块化应用程序开发、事件聚合器、导航、对话框、异常处理等功能。这些工具使开发人员能够更轻松地构建复杂的应用程序,并提供了一种可扩展和可重用的方法。 总之,使用WPF MVVM Prism可以使开发人员更轻松地构建复杂的应用程序,并提高应用程序的可维护性和可扩展性。开发人员可以根据自己的需求选择使用这个框架来开发WPF应用程序,从而提高他们的工作效率和代码质量。 ### 回答2: WPF MVVM Prism是一种基于Windows Presentation Foundation(WPF)的软件开发模式,采用了MVVM(Model-View-ViewModel)设计模式和Prism框架来实现软件开发MVVM是一种在WPF应用程序中使用的设计模式,它将应用程序的视图(View)与应用程序的模型(Model)分离开来,通过ViewModel来连接二者。Prism是一个帮助开发人员编写出复杂、可管控、可扩展和可维护的WPF应用程序的框架。 WPF MVVM Prism提供了很多好处:首先,它能实现软件的可重用性,通过将代码和视图分离,使得代码可以在多个不同的视图中重复使用,提高了开发效率。其次,它可以提高软件的可维护性,通过将逻辑和视图分离,确保逻辑代码与UI代码之间更少的耦合,提高了软件的可扩展性。此外,它还可以提高软件的可测试性,由于MVVM模式中将视图和逻辑分离开,所以开发人员可以更容易地编写出单元测试代码,来测试逻辑代码。最后,由于Prism框架提供了一些通用的,可定制的模块和服务,使得开发人员可以更快地实现常见功能、缩短开发时间。 总之,WPF MVVM Prism是一种高效、可扩展和易于维护的软件开发模式,它将视图和逻辑分离,提高了软件的可重用性和可测试性,同时也提高了软件的可扩展性和可复用性。 ### 回答3: WPF是一种桌面应用程序框架,它允许您为Windows创建高度交互式和可视化的应用程序界面。MVVM是一种软件编程模式,它将用户界面(UI)与业务逻辑分离,以便更好地实现可维护,可扩展和可组合的代码。Prism是一个WPF和Silverlight应用程序的组件库,它提供了一些可重用和可扩展的基础设施组件,帮助您更快速地构建、测试和维护WPF应用程序。因此,WPF MVVM Prism的组合可以帮助您更轻松高效地开发WPF应用程序。您可以使用MVVM模式来改进应用程序的结构和测试,使用Prism来更好地组织和可扩展您的代码,以及使用WPF来实现交互丰富的UI。同时还可以使用Prism提供的事件聚合器、导航器和模块化架构,实现更灵活的应用程序设计。WPF MVVM Prism的组合提供了一种更有效的方式来构建WPF应用程序,以满足现代用户体验的需求,并且更容易测试和维护,因此它已成为WPF应用程序开发的重要组合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值