如何在WPF + MVVM中正确提供用户反馈? (登录表格)

时间:2016-07-29 15:41:39

标签: c# wpf xaml mvvm

让我先说明我目前正在学习WPF和MVVM模式,所以我的问题可能是自我回答更有经验的开发人员。

我所拥有的是一个简单的登录表单,其中名称为 Textbox ,密码为 PasswordBox 。名称框绑定到模型,而密码框作为整个对象发送到命令(因为您无法绑定到其文本属性)。然后是一个执行登录命令的按钮。现在当登录工作正常时,我的问题是如何在不破坏mvvm模式的情况下发送命令失败的返回反馈。例如,将字段的边框颜色更改为红色。

我最初的直觉是拥有模型的属性,我将在失败时更改。但是我想学习正确的方法而不是自己破解解决方案(打败整个事物的目的)。

奖金问题: - 可以将属性绑定到语句 - 例如String.isNullOrEmpty(model.name)吗? - 我是否应完全放弃MVVM模式进行如此简单的操作(而项目的其余部分仍将使用它)> - 了解WPF和MVVM的好资源是什么?

下面的表格代码:

<Controls:MetroWindow x:Class="Interface_WPF.View.LoginWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:Controls="clr-namespace:MahApps.Metro.Controls;assembly=MahApps.Metro"
    Title="Enter" Height="140" Width="285" WindowStartupLocation="CenterScreen" WindowStyle="None" AllowsTransparency="True" ResizeMode="NoResize">
<StackPanel>
    <Grid FocusManager.FocusedElement="{Binding ElementName=NameBox}">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto" />
            <RowDefinition Height="Auto" />
        </Grid.RowDefinitions>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="Auto" />
            <ColumnDefinition Width="200" />
        </Grid.ColumnDefinitions>
        <Label Grid.Row="0" Grid.Column="0" Content="Name:"/>
        <Label Grid.Row="1" Grid.Column="0" Content="Password:"/>
        <TextBox Grid.Column="1" Grid.Row="0" Margin="3"
                 Name="NameBox" Text="{Binding Login.Name, UpdateSourceTrigger=PropertyChanged}"/>
        <PasswordBox Grid.Column="1" Grid.Row="1" Margin="3"
                 Name="PasswordBox"/>
    </Grid>
    <Button Command="{Binding LoginCheck}" 
            CommandParameter="{Binding ElementName=PasswordBox}" 
            Style="{DynamicResource SquareButtonStyle}" IsDefault="True" Width="100" HorizontalAlignment="Right" Margin="0,8,7.8,8" Content="Enter"/>
</StackPanel>

1 个答案:

答案 0 :(得分:1)

MVVM中没有关于代码隐藏中没有任何代码的规则 - 您只是不想在代码隐藏中使用BUSINESS LOGIC。 MVVM的许多新手都没有意识到这一点,这引起了许多令人头疼的问题。您可以在代码隐藏中添加尽可能多的视图逻辑,因为您希望处理诸如反馈消息框之类的内容。

现在,当你想提供具体的反馈时,你通常会做一些事情,比如让视图在viewmodel中执行一个返回布尔值的函数,如果它返回false,那么在viewmodel中显示一个带有属性内容的消息框具体的错误数据。人们喜欢处理这些事情的方式有几种。

永远记住MVVM不是宗教信仰,它是一种可以使用的工具,如果你想做什么,你可以在适合你的地方弯曲它 - 你决定什么是太多的层破坏了。