win10 UWP MvvmLight入门 安装MvvmLight新建ViewModel文件夹绑定参考

安装MvvmLight

我们安装的是MvvmLightLib。

右击项目,管理Nuget,搜索MVVM

安装第二个。他包含了运行的类库,我们将会使用里面的一些类。关于lib包含的库,参见:http://www.cnblogs.com/manupstairs/p/4890300.html

新建ViewModel文件夹

右击项目,新建文件夹ViewModel和View、Model三个文件夹。

在ViewModel文件夹新建类ViewModelLocator。

打开App.xaml

添加命名空间xmlns:viewModel="using:项目.ViewModel"

其中项目为你新建项目的名称

添加资源作为全局的ViewModel管理

    <Application.Resources>
        <ResourceDictionary>
            <viewModel:ViewModelLocator x:Key ="ViewModelLocator"></viewModel:ViewModelLocator>
        </ResourceDictionary>
    </Application.Resources>

接着假如我们有两个页面,一个是MainPage,一个是ChangeControlPage,那么我们就在ViewModel文件夹新建两个类MainModel和ChangeControlModel

他们继承ViewModelBase

接着在ViewModelLocator添加属性

 public ViewModel ViewModel => ServiceLocator.Current.GetInstance<ViewModel>();

注意,ViewModel 是多个ViewModel,也就是MainModel和ChangeControlModel,写法就是代换ViewModel为你的ViewModel

我们需要在ViewModelLocator的构造上用SimpleIoc.Default.Register

        public ViewModelLocator()
        {
            ServiceLocator.SetLocatorProvider(()=>SimpleIoc.Default);

            SimpleIoc.Default.Register<ViewModel>();
        }

接着打开MainPage.xaml,原来是在cs写我们的ViewModel实例,现在我们可以直接在xaml

    <Page.DataContext>
        <Binding Source="{StaticResource ViewModelLocator}" Path="ViewModel"></Binding>
    </Page.DataContext>

当然我们可以换个方式

    DataContext="{Binding Source={StaticResource ViewModelLocator},Path=ViewModel}"

绑定

我们先在ViewModel中新建字段_str,我们绑定到xaml

        public string Str
        {
            set
            {
                Set(ref _str, value);
            }
            get
            {
                return _str;
            }
        }

        private string _str;
        <TextBlock Text="{Binding Path=Str,Mode=OneWay}"
                   HorizontalAlignment="Center" VerticalAlignment="Center"></TextBlock>

我们可以把命令绑定到ViewModel,写法垃圾

        public ViewModel(INavigationService navigationService)
        {
            _navigationService = navigationService;
            Navigate = new RelayCommand(NavigateHigPage);
        }

        public ICommand Navigate
        {
            set;
            get;
        }

        private void NavigateHigPage()
        {
            
        }

我们继续做从Main跳到第二页面,第二页面叫HigPage

首先打开ViewModelLocator,在构造写一个帮我们传页面信息NavigationService

            var navigationService = new NavigationService();
            navigationService.Configure("main",typeof(MainPage));
            navigationService.Configure("hig",typeof(HightClipPage));
            SimpleIoc.Default.Register<INavigationService>(() => navigationService);

在需要跳转的函数

        private void NavigateHigPage()
        {
            var navigateService = ServiceLocator.Current.GetInstance<INavigationService>();
            navigateService.NavigateTo("hig","hellow");
        }

我跳转到第二页面,然后给他参数hellow

参考

http://www.cnblogs.com/manupstairs/


本文会经常更新,请阅读原文: https://lindexi.gitee.io/lindexi/post/win10-UWP-MvvmLight%E5%85%A5%E9%97%A8.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接: https://lindexi.gitee.io ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菩提树下的杨过

spring集成kafka

一、添加依赖项 compile 'org.springframework.kafka:spring-kafka:1.2.2.RELEASE' 二、发消息(生产者...

2298
来自专栏安恒网络空间安全讲武堂

赛前福利①最新2018HITB国际赛writeup

FIRST 距离“西湖论剑杯”全国大学生网络空间安全技能大赛只有10天啦! 要拿大奖、赢offer,那必须得来点赛前练习定定心啊~这不,讲武堂就拿到了2018H...

4705
来自专栏安恒网络空间安全讲武堂

[HCTF] share write up

从http://share.2018.hctf.io/robots.txt中获取到题目部分源码

1012
来自专栏狂码一生

PHP $_SERVER大全详解

$_SERVER['HTTP_ACCEPT_LANGUAGE']//浏览器语言  $_SERVER['REMOTE_ADDR'] //当前用户 IP 。  $_...

37512
来自专栏乐沙弥的世界

MySQL 系统变量(system variables)

    MySQL系统变量(system variables)实际上是一些系统参数,用于初始化或设定数据库对系统资源的占用,文件存放位置等等。这些个系统变量可以...

1322
来自专栏Fish

《深入理解Spark-核心思想与源码分析》读书笔记(1)

前两章 第一章主要是讲如何安装和配置spark,以及如何导入spark源码调试运行;第二章主要讲的是上次那本书《Spark快速大数据分析》的内容,科普一下spa...

29710
来自专栏一只程序汪的自我修养

手把手教你用.NET Core写爬虫

自从上一个项目58HouseSearch从.NET迁移到.NET core之后,磕磕碰碰磨蹭了一个月才正式上线到新版本。

35112
来自专栏林德熙的博客

WPF 轻量级 MVVM 框架入门 2.1.2 安装项目要求创建主页面找到 ViewModel通过附加属性找到 ViewModel跳转页面跳转命令自定义命令

本文告诉大家如何使用本金鱼的 MVVM 轻量框架。 一个好的框架是不需要解释就可以让大家使用,但是本金鱼没有这个能力,所以就写了这个文章告诉大家如何使用。

1522
来自专栏林德熙的博客

win10 uwp MVVM入门

MVVM 是一个强大的架构,基本从 WPF 开始,wr(我说的就是微软)就提倡使用 MVVM。它可以将界面和后台分离,让开发人员可以不关心界面是怎样,全心投入到...

851
来自专栏Android 研究

APK安装流程详解13——PMS中的新安装流程下(装载)

而在handleReturnCode()方法里面也是调用processPendingInstall(args, ret)方法,如下:

2692

扫码关注云+社区

领取腾讯云代金券