WPF中利用数据多条件触发器控制Button控件的可用性

前言
假设我们有两个文本框,需要输入姓名和年龄,且两项为必须输入的字段。这时候我们可以利用Validation类扩展自己的数据验证,同时将验证结果绑定到Button的IsEnabled属性上,当两个TextBox输入的值通过数据验证后,Button才可用。

首先,我们创建两个数据验证类

public class NameValidationRule : ValidationRule
    {
        public override ValidationResult Validate(object value, CultureInfo cultureInfo)
        {
            if (value == null || value.ToString().Length == 0)
            {
                return new ValidationResult(false, "姓名不能为空");
            }
            else
            {
                return new ValidationResult(true, null);
            }
        }    
    }
    
public override ValidationResult Validate(object value, CultureInfo cultureInfo)
        {
            if (double.TryParse(value.ToString(), out double myValue))
            {
                if (myValue >= 0 && myValue <= 100)
                {
                    return new ValidationResult(true, null);
                }
            }

            return new ValidationResult(false, "请输入 0 至 100的数字");
        }

然后我们编写前端代码

<Grid>
        <Grid Margin="50">
            <Grid.RowDefinitions>
                <RowDefinition/>
                <RowDefinition/>
                <RowDefinition/>
                <RowDefinition/>
            </Grid.RowDefinitions>
            <StackPanel Grid.Row="0" Orientation="Horizontal" HorizontalAlignment="Center">
                <TextBlock Text="姓名:" VerticalAlignment="Center"/>
                <TextBox x:Name="textBoxName" Width="200" Height="30" VerticalContentAlignment="Center">
                    <TextBox.Style>
                        <Style TargetType="TextBox">
                            <Style.Triggers>
                                <Trigger Property="Validation.HasError" Value="True">
                                    <Setter Property="ToolTip" Value="{Binding (Validation.Errors).CurrentItem.ErrorContent,RelativeSource={RelativeSource Mode=Self}}"/>
                                </Trigger>
                            </Style.Triggers>
                        </Style>
                    </TextBox.Style>
                    <TextBox.Text>
                        <Binding Path="Name" UpdateSourceTrigger="PropertyChanged">
                            <Binding.ValidationRules>
                                <validation:NameValidationRule ValidatesOnTargetUpdated="True"/>
                            </Binding.ValidationRules>
                        </Binding>
                    </TextBox.Text>
                    <Validation.ErrorTemplate>
                        <ControlTemplate>
                            <DockPanel>
                                <AdornedElementPlaceholder>
                                    <Border BorderBrush="Red" BorderThickness="1">
                                        <TextBlock HorizontalAlignment="Right" Foreground="LightGray" Background="Transparent"  Text="{Binding ErrorContent}"  VerticalAlignment="Center" Margin=" 10 0 10 0" />
                                    </Border>
                                </AdornedElementPlaceholder>
                            </DockPanel>
                        </ControlTemplate>
                    </Validation.ErrorTemplate>
                </TextBox>
            </StackPanel>
            <StackPanel Grid.Row="1" Orientation="Horizontal" HorizontalAlignment="Center">
                <TextBlock Text="年龄:" VerticalAlignment="Center"/>
                <TextBox x:Name="textBoxAge"  Width="200" Height="30" VerticalContentAlignment="Center">
                    <TextBox.Style>
                        <Style TargetType="TextBox">
                            <Style.Triggers>
                                <Trigger Property="Validation.HasError" Value="True">
                                    <Setter Property="ToolTip" Value="{Binding (Validation.Errors).CurrentItem.ErrorContent,RelativeSource={RelativeSource Mode=Self}}"/>
                                </Trigger>
                            </Style.Triggers>
                        </Style>
                    </TextBox.Style>
                    <TextBox.Text>
                        <Binding Path="Age" UpdateSourceTrigger="PropertyChanged">
                            <Binding.ValidationRules>
                                <validation:AgeValidationRule ValidatesOnTargetUpdated="True"/>
                            </Binding.ValidationRules>
                        </Binding>
                    </TextBox.Text>
                    <Validation.ErrorTemplate>
                        <ControlTemplate>
                            <DockPanel>
                                <AdornedElementPlaceholder>
                                    <Border BorderBrush="Red" BorderThickness="1">
                                        <TextBlock HorizontalAlignment="Right" Foreground="LightGray"  Text="{Binding ErrorContent}"  VerticalAlignment="Center" Margin=" 10 0 10 0" />
                                    </Border>
                                </AdornedElementPlaceholder>
                            </DockPanel>
                        </ControlTemplate>
                    </Validation.ErrorTemplate>
                </TextBox>
            </StackPanel>
            <StackPanel Grid.Row="2">
                <Button Content="提  交" Width="80" Height="30">
                    <Button.Style>
                        <Style TargetType="Button">
                            <Setter Property="IsEnabled" Value="False"/>
                            <Style.Triggers>
                                <MultiDataTrigger>
                                    <MultiDataTrigger.Conditions>
                                        <Condition Binding="{Binding ElementName=textBoxName,Path=(Validation.HasError)}" Value="False"/>
                                        <Condition Binding="{Binding ElementName=textBoxAge,Path=(Validation.HasError)}" Value="False"/>
                                    </MultiDataTrigger.Conditions>
                                    <MultiDataTrigger.Setters>
                                        <Setter Property="IsEnabled" Value="True"/>
                                    </MultiDataTrigger.Setters>
                                </MultiDataTrigger>
                            </Style.Triggers>
                        </Style>
                    </Button.Style>
                </Button>
            </StackPanel>
        </Grid>
    </Grid>

注意我们的Name和Age两个字段位于ViewModel当中

public class ValidationWindowViewModel : ViewModelBase
    {
        private int age;

        public int Age
        {
            get { return age; }
            set { age = value; RaisePropertyChanged(); }
        }

        private string  name;

        public string Name
        {
            get { return name; }
            set { name = value; RaisePropertyChanged(); }
        }

    }

这样就实现了数据验证和提交按钮绑定的要求。如下图:
在这里插入图片描述
由于只输入了张三,没有年龄,所以按钮是灰色
在这里插入图片描述
输入姓名和年龄,通过验证,按钮可用

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Blend创建WPF自定义Button控件,可以按照以下步骤进行: 1. 打开Blend,创建一个新的WPF项目。 2. 在“项目”面板,右键单击“控件”文件夹,选择“添加”->“新建项”。 3. 在“添加新项”对话框,选择“WPF”->“Custom Control”,设置名称为“CustomButton”并选择位置,点击“添加”按钮。 4. Blend会自动生成一个名为“CustomButton”的自定义控件的类文件和一个默认的控件模板文件。 5. 双击控件模板文件,进入“编辑模板”模式。在这里,你可以自由地编辑控件的外观和布局。 6. 在“对象和时间”面板,可以选择控件的外观和行为。例如,你可以添加按钮、文本框等控件,设置它们的属性和事件处理程序。 7. 在控件模板,找到名为“PART_Button控件的模板,这是自定义控件按钮。你可以编辑它的外观和行为,以实现自定义Button控件的功能和样式。 8. 在编辑完成后,保存模板文件并退出“编辑模板”模式。 9. 在CustomButton,添加自定义属性和事件处理程序,以实现自定义Button控件的功能。 10. 在应用程序,使用自定义Button控件,只需要在XAML添加一个CustomButton标记,然后设置它的属性和事件处理程序即可。 以上就是在Blend创建WPF自定义Button控件的基本步骤。需要注意的是,在创建控件时,应该考虑控件的可重用性和灵活性,以便在不同的场景使用。同时,应该设计好控件的外观和行为,以便用户可以方便地使用和定制控件

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值