wpf textbox框失去焦点,使值及时更新到viewmodel中对应的字段

背景

在页面上用textbox框显示值,textbox的值改变后,但是不会立即传递到viewmodel中:

下面两种方式实现:

在WPF (Windows Presentation Foundation) 中,如果您希望当用户在TextBox中有焦点时点击页面上的空白区域,使焦点从TextBox移开,您可以通过为包含TextBox的容器(如Grid或Panel)或根窗口添加鼠标事件处理器来实现。以下是一种可能的方法:

为您的容器或窗口添加一个MouseDown事件处理器。

在事件处理器中,检查当前具有焦点的元素是否是TextBox。

如果是,将焦点设置到其他元素上,或者简单地使用Keyboard.ClearFocus();来清除焦点。

xaml

csharp 复制代码
<Window x:Class="WpfApp.MainWindow"  
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
        Title="MainWindow" Height="350" Width="525"  
        MouseDown="Window_MouseDown">  
    <Grid>  
        <TextBox x:Name="MyTextBox" HorizontalAlignment="Left" Height="23" Margin="10" TextWrapping="Wrap" Text="{Binding MyProperty, Mode=TwoWay, UpdateSourceTrigger=LostFocus}" VerticalAlignment="Top" Width="120"/>  
        <!-- 其他UI元素 -->  
    </Grid>  
</Window>

C#代码

csharp 复制代码
private void Window_MouseDown(object sender, MouseButtonEventArgs e)  
{  
    if (FocusManager.GetFocusedElement(this) is TextBox)  
    {  
        // 您可以选择将焦点设置到特定元素,或者简单地清除焦点  
        Keyboard.ClearFocus();  
    }  
}

2.如果上面这种方式没有成功,用第二种

如果您在TextBox中使用Keyboard.ClearFocus()来清除焦点,但发现ViewModel的值没有更新,可能是因为数据绑定的更新机制没有被正确触发。

虽然默认情况下TextBox的UpdateSourceTrigger是LostFocus,但如果您在绑定中明确指定了其他值(如PropertyChanged),则可能会更改更新的行为。如果您想要在每次TextBox值改变时立即更新ViewModel,可以将UpdateSourceTrigger设置为PropertyChanged。

xaml

csharp 复制代码
<TextBox Text="{Binding MyProperty, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" />

将对应的textbox 中的LostFocus 改为PropertyChanged 即可。

csharp 复制代码
UpdateSourceTrigger=PropertyChanged
相关推荐
张人玉1 天前
C#WPF UI路由事件:事件冒泡与隧道机制
ui·c#·wpf
Aevget2 天前
DevExpress WPF v25.2新功能预览 - 支持将JetBrains Rider与报表设计器集成
.net·wpf·界面控件·devexpress·ui开发
Aevget2 天前
界面控件DevExpress WPF v25.1新版亮点:AI功能的全面升级
c#·.net·wpf·界面控件·devexpress·ui开发
beyond谚语3 天前
第一章 WPF概述
wpf
necessary6534 天前
从工行“余额归零”事件看CAP定理:当金融系统在一致性与可用性之间做出选择
分布式·金融·wpf·可用性测试
棉晗榜4 天前
WPF隐藏控件后,怎么让其上部的控件空间自动撑高
wpf
壹佰大多5 天前
【Redisson分布式锁源码分析-3】
数据结构·分布式·mysql·spring·spring cloud·wpf·lua
LateFrames5 天前
以小白视角尝试 WPF / WinUI3 / MAUI / MAUI Blazor 构建 Windows 桌面程序
windows·wpf·maui·mauiblazor·winui3
偶尔的鼠标人6 天前
Avalonia/WPF 打开子窗口,并且跨页面传值
c#·wpf·mvvm·avalonia
玖笙&6 天前
✨WPF编程进阶【6.1】:图形原则(附源码)
c++·c#·wpf·visual studio