在 MVVM WPF 应用程序中使用本地视图模型

本文关键字:视图 模型 MVVM WPF 应用程序 | 更新日期: 2023-09-27 18:32:47

我在使用视图时无法访问我的视图模型。

我有一个名为BankManagerApplication的项目。其中我有与新的 WPF 应用程序关联的各种文件。我创建了三个单独的文件夹模型,视图模型视图

目前,模型文件夹中有一个 UserModel 类,其中包含以下字段;

namespace BankManagerApplication.Model
{
    public class UserModel
    {
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public double AccountBallance { get; set; }
    }
}

"视图"文件夹中的空白视图,里面只有一个网格;

<Window x:Class="BankManagerApplication.View.MainWindowView"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindowView" Height="300" Width="300">
    <Grid>
    </Grid>
</Window>
以及视图模型

文件夹中的空白视图模型;

namespace BankManagerApplication.ViewModel
{
    public class MainWindowViewModel
    {
    }
}

当我尝试像这样在我的 XAML 中引用视图模型时;

<Window x:Class="BankManagerApplication.View.MainWindowView"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindowView" Height="300" Width="300"
        xmlns:viewmodel="clr-namespace:BankManagerApplication.ViewModel">
    <Grid>
        <viewmodel:MainWindowViewModel></viewmodel:MainWindowViewModel>
    </Grid>
</Window>

我收到错误

命名空间中不存在名称"MainWindowViewModel" "clr-namespace:BankManagerApplication.ViewModel'

才刚刚开始学习 WPF,这个错误在我真正开始之前就让我失望了

在 MVVM WPF 应用程序中使用本地视图模型

不能将其添加到网格控件,因为它不是 UIElement。您的视图模型将是视图的数据上下文:

<Window x:Class="BankManagerApplication.View.MainWindowView"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="MainWindowView" Height="300" Width="300"
    xmlns:viewmodel="clr-namespace:BankManagerApplication.ViewModel">
    <Window.DataContext>
       <viewmodel:MainWindowViewModel></viewmodel:MainWindowViewModel>
    </Window.DataContext>
    <Grid>
    </Grid>