验证XAML中的密码和密码确认

时间:2014-04-23 03:38:42

标签: c# wpf xaml mvvm

我正在使用MVVM,我的舞台是:我有两个PasswordBox

        <PasswordBox x:Name="Password" Width="150" Height="30" />
        <PasswordBox x:Name="PasswordConfirmation" Width="150" Height="30" />

我想在Password和PasswordConfirmation之间对xaml进行验证。与网站中的JQuery类似。

我不想破坏MVVM,我的意思是,我不想让代码落后。

1 个答案:

答案 0 :(得分:0)

如果您可以容忍IMultiValueConverter的代码,以下是MVVM。

<Page.Resources>
    <local:ConfirmPasskey x:Key="ConfirmPasskey" />
</Page.Resources>

...

<PasswordBox x:Name="_PassKey" Grid.Column="1" Grid.Row="1" Margin="0,5,5,0"
    LostFocus="Update_PassCheckError"/>
<PasswordBox x:Name="_PassCheck" Grid.Column="1" Grid.Row="2" Margin="0,5,5,0" 
    LostFocus="Update_PassCheckError" />
<TextBlock x:Name="_PassCheckError" Grid.ColumnSpan="2" Grid.Row="3" Margin="5,5,5,5"
    Foreground="Red" HorizontalAlignment="Center" >
        <TextBlock.Text>
            <MultiBinding Converter="{StaticResource ConfirmPasskey}" Mode="OneWay" >
                <Binding ElementName="_PassKey" />
                <Binding ElementName="_PassCheck" />
            </MultiBinding>
         </TextBlock.Text>
 </TextBlock>

我使用TextBlock,因为我想提供伪装饰,但可以使用任何依赖属性,例如登录提示按钮的IsEnabled属性的布尔值。这是我的IMultiValueConverter,它可以返回一个bool而不是密码验证文本:

public class ConfirmPasskey : IMultiValueConverter
{
    public object Convert(object[] values, Type targetType, object parm, System.Globalization.CultureInfo culture)
    {
        bool match = (values[0] as PasswordBox).Password.Equals((values[1] as PasswordBox).Password);

        if (targetType.Name.Equals("Nullable`1"))
            return match;

        return (match) ? null : "Passcodes do not match.";
    }

    public object[] ConvertBack(object value, Type[] targetTypes, object parm, System.Globalization.CultureInfo culture)
    {
        throw new NotImplementedException();
    }
}