在 Furion 中,表單驗證通常是通過數據注解(Data Annotations)和模型驗證(Model Validation)來實現的。以下是如何在 Winform 應用程序中使用 Furion 進行表單驗證的步驟:
dotnet add package Furion
dotnet add package Furion.Extras
public class UserViewModel
{
[Required(ErrorMessage = "用戶名不能為空")]
[StringLength(10, ErrorMessage = "用戶名長度不能超過10個字符")]
public string Username { get; set; }
[Required(ErrorMessage = "密碼不能為空")]
[StringLength(20, ErrorMessage = "密碼長度不能超過20個字符")]
public string Password { get; set; }
[Required(ErrorMessage = "郵箱不能為空")]
[EmailAddress(ErrorMessage = "郵箱格式不正確")]
public string Email { get; set; }
}
public partial class MainForm : Form
{
private readonly UserViewModel _userViewModel = new();
public MainForm()
{
InitializeComponent();
// 綁定視圖模型到控件
usernameTextBox.DataBindings.Add(nameof(usernameTextBox.Text), _userViewModel, nameof(_userViewModel.Username));
passwordTextBox.DataBindings.Add(nameof(passwordTextBox.Text), _userViewModel, nameof(_userViewModel.Password));
emailTextBox.DataBindings.Add(nameof(emailTextBox.Text), _userViewModel, nameof(_userViewModel.Email));
}
}
App.Validate
方法對視圖模型進行驗證。如果驗證失敗,將錯誤信息顯示給用戶。例如:private void submitButton_Click(object sender, EventArgs e)
{
// 驗證視圖模型
var validationResults = App.Validate(_userViewModel);
if (validationResults.IsValid)
{
// 驗證成功,處理表單數據
MessageBox.Show("表單提交成功!");
}
else
{
// 驗證失敗,顯示錯誤信息
var errorMessage = string.Join(Environment.NewLine, validationResults.Errors.Select(e => e.ErrorMessage));
MessageBox.Show(errorMessage, "表單驗證失敗", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
現在,當用戶提交表單時,Furion 將根據視圖模型中定義的數據注解規則對表單數據進行驗證。如果驗證失敗,將顯示相應的錯誤信息。