如何创建Mvvmlight WPF程序

创建步骤

创建Mvvm结构的开发环境很简单,首先在View层的App.xaml文件中引用ViewModel层,设置全局资源。

其次,给主窗体设置数据源并设置绑定

接着,在ViewModel层新建定位器和主窗体绑定的类

定位器中相关代码

如果是使用NuGet导入MvvmLight,就会自动创建好了这个ViewModelLocator类,在类的构造函数中会带有这个

ServiceLocator.SetLocatorProvider(() => SimpleIoc.Default);

关于这个我也不清楚有什么作用,毕竟SimpleIoc.Default中就继承了IServiceLocator。

这里使用的SimpleIoc,可以去以下链接浏览,这里对mvvmLight做了详细的介绍:

https://www.cnblogs.com/maanshancss/p/5794780.html

简要介绍一下,就是使用了SimpleIoc容器,使用依赖注入的方式将ViewModel类注册进去容器中,也可将一些服务,公共全局变量注册进去,例如:

        public ViewModelLocator()
        {
            ServiceLocator.SetLocatorProvider(() => SimpleIoc.Default);
            SimpleIoc.Default.Register<IDataService, DataService>();//公共变量交换器
            SimpleIoc.Default.Register<MainWindowViewModel>();//主窗口ViewModel
            SimpleIoc.Default.Register<TextViewModel>();//测试窗口ViewModel
            //创建导航服务,并将导航服务注册进容器
            var navigationService = this.CreateNavigationService();
            SimpleIoc.Default.Register<INavigationService>(() => navigationService);
        }
        /// <summary>
        /// 主窗口
        /// </summary>
        public MainWindowViewModel MainWindowViewModel
        {
            get
            {
                return ServiceLocator.Current.GetInstance<MainWindowViewModel>();
            }
        }
        /// <summary>
        /// 测试窗口
        /// </summary>
        public TextViewModel TextViewModel
        {
            get
            {
                return ServiceLocator.Current.GetInstance<TextViewModel>();
            }
        }
        /// <summary>
        /// 创建导航服务
        /// </summary>
        /// <returns></returns>
        private INavigationService CreateNavigationService()
        {
            var navigationService = new NavigationService();
            //主窗口
            navigationService.Configure(ViewNames.MAIN_VIEW, new Uri("/MainWindow.xaml", UriKind.RelativeOrAbsolute));
            /
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
登录功能可以通过MVVMLight来实现。MVVMLight是一个用于WPF应用程序的轻量级MVVM框架,它提供了一套简单易用的命令、绑定和导航功能,可以帮助我们更方便地实现登录功能。 首先,我们可以在ViewModel中创建一个LoginViewModel来处理登录逻辑。在LoginViewModel中,我们可以定义用户名和密码的属性,并提供一个登录命令,当用户点击登录按钮时触发。 接下来,我们可以在View中创建一个登录页面,其中包含用户名和密码的输入框以及一个登录按钮。我们可以使用MVVMLight的Binding功能,将输入框与LoginViewModel中的属性进行绑定,以实现双向数据绑定。 当用户点击登录按钮时,MVVMLight的Command功能可以帮助我们触发LoginViewModel中的登录命令,并执行登录逻辑。在登录命令中,我们可以验证用户输入的用户名和密码,并根据验证结果进行相应的处理,比如跳转到主页面或显示错误消息等。 总结来说,使用MVVMLight可以简化WPF应用程序中的MVVM开发,包括登录功能的实现。需要注意的是,我们需要下载并编译MVVMLight库,并按照文档中的说明来使用它来搭建MVVM设计框架。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [MVVMLight页面跳转WPF](https://download.csdn.net/download/nowaycw/10638125)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [WPF MVVMLight框架使用源码,可运行看效果](https://download.csdn.net/download/Hylunhe/12048470)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值