syncfusion-wpf-maskedtextbox
Implementing Syncfusion WPF MaskedTextBox (SfMaskedEdit)
The WPF MaskedTextBox (SfMaskedEdit) is an advanced input control that restricts user input to specific types using mask patterns. It's ideal for creating templates for phone numbers, IP addresses, product IDs, dates, and other formatted data entry.
When to Use This Skill
Use this skill when you need to:
- Restrict input to specific formats without custom validation
- Implement formatted input fields for phone numbers, emails, dates, currency
- Create mask patterns using Simple or RegEx mask types
- Validate user input on key press or lost focus
- Format values with or without literals and prompt characters
- Display error indicators for invalid input
- Add watermarks to guide user input
- Customize appearance including colors, borders, and themes
- Support RTL layouts for international applications
- Handle value changes with event notifications
Component Overview
SfMaskedEdit provides:
- Multiple mask types: Simple and RegEx patterns
- Flexible validation: KeyPress or LostFocus validation modes
- Value formatting: Include/exclude prompts and literals
- Visual feedback: Error borders, prompt characters, watermarks
- Full customization: Colors, themes, templates
- MVVM support: Data binding and property change notifications
Assembly: Syncfusion.SfInput.WPF, Syncfusion.SfShared.WPF
Namespace: Syncfusion.Windows.Controls.Input
Documentation and Navigation Guide
Getting Started
📄 Read: references/getting-started.md
- Assembly deployment and NuGet installation
- Adding SfMaskedEdit via designer, XAML, and C#
- Basic configuration and setup
- First masked textbox example
- Handling ValueChanged events
Mask Patterns and Input Restriction
📄 Read: references/mask-patterns-input-restriction.md
- Mask element reference ([], \d, \w, {n}, +, *, ?, etc.)
- Creating custom mask patterns
- Allow/restrict specific values with (?=) and (?!)
- Extensive mask examples (phone, email, currency, dates, etc.)
- Input validation modes (KeyPress vs LostFocus)
- Validation results and HasError property
- PromptChar and ShowPromptOnFocus configuration
Value Management
📄 Read: references/value-management.md
- Setting and getting Value property
- ValueMaskFormat options:
- ExcludePromptAndLiterals
- IncludeLiterals
- IncludePrompt
- IncludePromptAndLiterals
- Value change notifications
- Clipboard operations with formatted values
Appearance and Customization
📄 Read: references/appearance-customization.md
- Background, Foreground, and SelectionBrush
- CaretBrush and BorderBrush customization
- ErrorBorderBrush for validation feedback
- FlowDirection for RTL support
- Watermark and WatermarkTemplate
- Theme integration and styling
Quick Start Example
Phone Number Mask
<Window xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:syncfusion="http://schemas.syncfusion.com/wpf"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<Grid>
<syncfusion:SfMaskedEdit
x:Name="phoneNumber"
Mask="\([0-9]\d{2}\) [0-9]\d{2}-[0-9]\d{3}"
MaskType="RegEx"
Value="4553456789"
PromptChar="_"
Width="200"
Height="30"
ValueChanged="PhoneNumber_ValueChanged"/>
</Grid>
</Window>
using Syncfusion.Windows.Controls.Input;
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private void PhoneNumber_ValueChanged(object sender, EventArgs e)
{
var maskedEdit = sender as SfMaskedEdit;
if (!maskedEdit.HasError)
{
// Use formatted value: (455) 345-6789
string formattedPhone = maskedEdit.Value;
}
}
}
Common Patterns
Pattern 1: Email Validation
<syncfusion:SfMaskedEdit
Mask="[A-Za-z0-9._%-]+@[A-Za-z0-9]+\.[A-Za-z]{2,3}"
MaskType="RegEx"
Watermark="Enter email address"
ErrorBorderBrush="Red"/>
Pattern 2: Currency Input
<syncfusion:SfMaskedEdit
Mask="$ \d+\.\d{2}"
MaskType="RegEx"
Value="1234.56"
ValueMaskFormat="IncludeLiterals"/>
Pattern 3: Date Input with Validation
<syncfusion:SfMaskedEdit
Mask="(0[1-9]|1[0-2])/(0[1-9]|[12][0-9]|3[01])/\d{4}"
MaskType="RegEx"
ValidationMode="LostFocus"
PromptChar="X"
ShowPromptOnFocus="True"/>
Pattern 4: Product Key
<syncfusion:SfMaskedEdit
Mask="[A-Z\d]{5}-[A-Z\d]{5}-[A-Z\d]{5}-[A-Z\d]{5}-[A-Z\d]{5}"
MaskType="RegEx"
ValueMaskFormat="ExcludePromptAndLiterals"/>
Pattern 5: Get Value Without Formatting
// Get only user-entered digits (no literals or prompts)
sfMaskedEdit.ValueMaskFormat = MaskFormat.ExcludePromptAndLiterals;
string digitsOnly = sfMaskedEdit.Value; // "4553456789"
// Get with formatting literals
sfMaskedEdit.ValueMaskFormat = MaskFormat.IncludeLiterals;
string formatted = sfMaskedEdit.Value; // "(455) 345-6789"
Key Properties
| Property | Type | Description |
|---|---|---|
| Mask | string | Mask pattern (null = no mask) |
| MaskType | MaskType | Simple or RegEx (default: Simple) |
| Value | string | Current value with formatting based on ValueMaskFormat |
| ValueMaskFormat | MaskFormat | Include/exclude prompts and literals |
| ValidationMode | InputValidationMode | KeyPress or LostFocus (default: KeyPress) |
| HasError | bool | True if validation failed (read-only) |
| PromptChar | char | Character for missing input (default: '_') |
| ShowPromptOnFocus | bool | Show prompts on focus vs while typing |
| ErrorBorderBrush | Brush | Border color for validation errors (default: Red) |
| Watermark | object | Text shown when empty |
| WatermarkTemplate | DataTemplate | Custom template for watermark |
Common Mask Patterns
| Use Case | Mask Pattern |
|---|---|
| Positive/negative numbers | -?\d+\.?\d* |
| Currency | $ \d+\.\d{2} |
| Percent | \d+\.\d{2}% |
[A-Za-z0-9._%-]+@[A-Za-z0-9]+\.[A-Za-z]{2,3} |
|
| Phone (US) | \([0-9]\d{2}\) [0-9]\d{2}-[0-9]\d{3} |
| Credit Card | \d{4} \d{4} \d{4} \d{4} |
| Time (24h) | `(0[0-9] |
| Zip Code | \d{5}-\d{4} |
| Product Key | [A-Z\d]{5}-[A-Z\d]{5}-[A-Z\d]{5} |
| Hexadecimal | \\x[0-9A-Fa-f]{1,2} |
Common Use Cases
Data Entry Forms
Use SfMaskedEdit in forms requiring formatted input like contact information, financial data, or identification numbers. Reduces validation code and improves UX.
Phone Number Collection
Implement consistent phone number formatting across your application with automatic formatting and validation.
Financial Applications
Enforce currency, decimal, and percentage formats for accounting and financial data entry.
Product Registration
Validate product keys, serial numbers, and license codes with custom patterns.
Date and Time Input
Create custom date/time formats beyond standard DatePicker controls with RegEx validation.
International Support
Use FlowDirection for RTL languages and customize masks for regional formats (dates, phone numbers).
Real-time Validation
Validate input on each keystroke (KeyPress) or on field exit (LostFocus) based on UX requirements.
Events
| Event | Description |
|---|---|
| ValueChanged | Fires when Value property changes (based on ValidationMode) |
| LostFocus | Standard WPF event, useful with LostFocus validation mode |
Best Practices
- Choose appropriate MaskType: Use RegEx for complex patterns, Simple for basic scenarios
- Set ValueMaskFormat early: Determine format before accessing Value property
- Provide visual feedback: Use ErrorBorderBrush and Watermark for better UX
- Match validation mode to UX: KeyPress for instant feedback, LostFocus for less intrusive validation
- Document custom patterns: Comment complex RegEx masks for maintainability
- Test edge cases: Verify behavior with empty input, partial input, and boundary values
- Use ShowPromptOnFocus: Enable for better visibility of expected input format
Next Steps: Choose a reference file above based on your needs, or start with getting-started.md for initial setup.