Share via


RequiredStringValidationBehavior

RequiredStringValidationBehavior は、テキスト入力が特定のテキストと等しいかどうかをユーザーが判断できるようにする Behavior です。 たとえば、Entry コントロールは、有効なテキスト入力と無効なテキスト入力のどちらが指定されているかに応じて、スタイルを変えることができます。

重要

.NET MAUI Community Toolkit のビヘイビアーでは、ビヘイビアーの BindingContext は設定されません。ビヘイビアーはスタイルを利用して共有し、複数のコントロールに適用できるためです。 詳細については、「.NET MAUI のビヘイビアー」を参照してください

構文

次の例は、RequiredStringValidationBehaviorEntry に追加し、RequiredString が入力されたかどうかに基づいて TextColor を変更する方法を示しています。

XAML

XAML 名前空間を含める

XAML でこのツールキットを使用するには、次の xmlns をページまたはビューに追加する必要があります。

xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"

したがって、以下のコードは、

<ContentPage
    x:Class="CommunityToolkit.Maui.Sample.Pages.MyPage"
    xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml">

</ContentPage>

次のように、xmlns を含むように変更されます。

<ContentPage
    x:Class="CommunityToolkit.Maui.Sample.Pages.MyPage"
    xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
    xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit">

</ContentPage>

RequiredStringValidationBehavior の使用

RequiredStringValidationBehavior は、XAML では次のように使用できます。

<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
             x:Class="CommunityToolkit.Maui.Sample.Pages.Behaviors.RequiredStringValidationBehaviorPage">

    <ContentPage.Resources>
        <Style x:Key="InvalidEntryStyle" TargetType="Entry">
            <Setter Property="TextColor" Value="Red" />
        </Style>
        <Style x:Key="ValidEntryStyle" TargetType="Entry">
            <Setter Property="TextColor" Value="Green" />
        </Style>
    </ContentPage.Resources>

    <Entry>
        <Entry.Behaviors>
            <toolkit:RequiredStringValidationBehavior 
                InvalidStyle="{StaticResource InvalidEntryStyle}"
                ValidStyle="{StaticResource ValidEntryStyle}"
                Flags="ValidateOnValueChanged"
                RequiredString="MAGIC ANSWER" />
        </Entry.Behaviors>
    </Entry>

</ContentPage>

C#

RequiredStringValidationBehavior は、C# では次のように使用できます。

class RequiredStringValidationBehaviorPage : ContentPage
{
    public RequiredStringValidationBehaviorPage()
    {
        var entry = new Entry();

        var validStyle = new Style(typeof(Entry));
        validStyle.Setters.Add(new Setter
        {
            Property = Entry.TextColorProperty,
            Value = Colors.Green
        });

        var invalidStyle = new Style(typeof(Entry));
        invalidStyle.Setters.Add(new Setter
        {
            Property = Entry.TextColorProperty,
            Value = Colors.Red
        });

        var requiredStringValidationBehavior = new RequiredStringValidationBehavior
        {
            InvalidStyle = invalidStyle,
            ValidStyle = validStyle,
            Flags = ValidationFlags.ValidateOnValueChanged,
            RequiredString = "MAGIC ANSWER"
        };

        entry.Behaviors.Add(requiredStringValidationBehavior);

        Content = entry;
    }
}

C# Markup

この CommunityToolkit.Maui.Markup パッケージは、C# でこの Behavior を使用するより簡潔な方法を提供します。

using CommunityToolkit.Maui.Markup;

class RequiredStringValidationBehaviorPage : ContentPage
{
    public RequiredStringValidationBehaviorPage()
    {
        Content = new Entry()
            .Behaviors(new RequiredStringValidationBehavior
            {
                InvalidStyle = new Style<Entry>(Entry.TextColorProperty, Colors.Red),
                ValidStyle = new Style<Entry>(Entry.TextColorProperty, Colors.Green),
                Flags = ValidationFlags.ValidateOnValueChanged,
                RequiredString = "MAGIC ANSWER"
            });
    }
}

次のスクリーンショットは、Android 上での RequiredStringValidationBehavior の結果を示しています。Android 上の RequiredStringValidationBehavior のスクリーンショット

Properties

プロパティ タイプ 説明
ExactMatch bool 入力されたテキストが RequiredString プロパティの内容全体と一致する必要があるのか、あるいは単に RequiredString プロパティ値を含んでいるだけで良いのかを決定します。
RequiredString string ユーザーによって提供された値と比較される文字列。

ValidationBehavior プロパティ

基底クラス public abstract class ValidationBehavior には、次のプロパティが実装されています。

プロパティ タイプ 説明
Flags ValidationFlags 検証の処理方法を指定する列挙値を提供します。
ForceValidateCommand ICommand 検証の強制を処理するカスタムの ICommand をユーザーが提供できるようにします。
InvalidStyle Style 検証が失敗した場合に要素に適用する Style
IsNotValid bool 現在の値が無効と見なされるかどうかを示します。
IsRunning bool 検証が現在進行中 (非同期呼び出しの終了待ち) かどうかを示します。
IsValid bool 現在の値が有効と見なされるかどうかを示します。
ValidStyle Style 検証が成功した場合に要素に適用する Style
Value object 検証する値。
ValuePropertyName string 検証対象の値として使用されるプロパティをユーザーがオーバーライドできるようにします。

このビヘイビアーの動作の例は .NET MAUI Community Toolkit サンプル アプリケーションで確認できます。

API

RequiredStringValidationBehavior のソース コードは、.NET MAUI Community Toolkit の GitHub リポジトリにあります。