文本框的 wpf 丢失焦点事件
本文关键字:焦点 事件 wpf 文本 | 更新日期: 2023-09-27 18:36:30
这是我的xaml结构
<StackPanel>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="A"
LostFocus="text_LostFocus"/>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="B"
LostFocus="text_LostFocus"/>
</StackPanel>
=> 此结构可以循环更多。如:
<StackPanel>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="A"
LostFocus="text_LostFocus"/>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="B"
LostFocus="text_LostFocus"/>
</StackPanel>
<StackPanel>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="A"
LostFocus="text_LostFocus"/>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="B"
LostFocus="text_LostFocus"/>
</StackPanel>
.cs文件中,我将事件失去焦点定义为如下
private void text_LostFocus(object sender, RoutedEventArgs e)
{
TextBox textbox = ((TextBox)sender);
if (textbox.Text.Trim().Length == 0)
{
System.Windows.Forms.DialogResult result1 = System.Windows.Forms.MessageBox.Show("Empty string!", "Warning",
System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Exclamation);
textbox.Dispatcher.BeginInvoke((Action)(() => { textbox.Focus(); }));
return;
}
textbox.ScrollToHome();
}
问题:如果有>= 2 个文本框的值为空 (")。
- 我单击第一个空文本框 => 我没有输入任何字符。
- 然后我单击第二个空文本框。
==>程序始终显示消息框=>如果我单击"确定"按钮,它会显示另一个。它永远发生。我无法关闭程序。
问题:如果我有>= 2 个空文本框,并且我与上述问题相同。如何更改函数text_LostFocus
来解决问题???
默认值:
这些文本框的值始终为空(默认值)
必须使用 开始调用 => 因为我希望当用户单击文本框时,用户必须至少输入一个字符。
如果我是你,我不会使用MessageBox。WPF 有一个非常好的"绑定验证框架"(查看此处以获取非常好的教程)。否则,我将在每个文本框附近创建一个"警告"标签:
<StackPanel>
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="A"
LostFocus="text_LostFocus"/>
<TextBlock Name="AWarning" Foreground="Red" />
<m:TextBoxWithEllipsis IsEllipsisEnabled="True"
Name="B"
LostFocus="text_LostFocus"/>
<TextBlock Name="BWarning" Foreground="Red" />
</StackPanel>
然后在代码隐藏中:
private void text_LostFocus(object sender, RoutedEventArgs e)
{
TextBox textBox = ((TextBox)sender);
TextBlock textBlock = FindName(String.Concat(textBox.Name, "Warning")) as TextBlock;
textBlock.Text = String.IsNullOrWhiteSpace(textBox.Text) ? "Empty string!" : String.Empty;
}