WPF의 ViewModel을 통해 TextBox의 포커스 설정
WPF 보기에서 버튼 클릭 이벤트를 처리할 때 오류 메시지를 표시한 다음 특정 TextBox 컨트롤로 포커스를 이동해야 할 수도 있습니다. 그러나 ViewModel에서 다음 코드를 실행해도 커서가 원하는 TextBox로 설정되지 않습니다.
<code class="language-csharp">if (companyref == null) { var cs = new Lipper.Nelson.AdminClient.Main.Views.ContactPanels.CompanyAssociation(); MessageBox.Show("Company does not exist.", "Error", MessageBoxButton.OK, MessageBoxImage.Exclamation); cs.txtCompanyID.Focusable = true; System.Windows.Input.Keyboard.Focus(cs.txtCompanyID); }</code>
이 문제의 원인은 ViewModel에서 직접 UI 요소를 참조하는 것입니다. 이는 일반적으로 권장되지 않는 방식입니다. 이 문제를 해결하려면 다른 기술을 사용해야 합니다.
첨부된 속성 사용
한 가지 접근 방식은 모든 UIElement에 적용할 수 있고 "IsFocused"와 같은 ViewModel 속성에 바인딩할 수 있는 연결된 속성을 만드는 것입니다. 이 속성의 값이 변경되면 요소의 포커스가 설정되어 이를 ViewModel의 상태에 바인딩할 수 있습니다. 이 연결된 속성의 구현은 다음과 같습니다.
<code class="language-csharp">public static class FocusExtension { public static bool GetIsFocused(DependencyObject obj) { return (bool)obj.GetValue(IsFocusedProperty); } public static void SetIsFocused(DependencyObject obj, bool value) { obj.SetValue(IsFocusedProperty, value); } public static readonly DependencyProperty IsFocusedProperty = DependencyProperty.RegisterAttached( "IsFocused", typeof(bool), typeof(FocusExtension), new UIPropertyMetadata(false, OnIsFocusedPropertyChanged)); private static void OnIsFocusedPropertyChanged( DependencyObject d, DependencyPropertyChangedEventArgs e) { var uie = (UIElement)d; if ((bool)e.NewValue) { uie.Focus(); // 忽略 false 值。 } } }</code>
그런 다음 XAML에서 이 추가 속성을 사용하여 ViewModel의 속성에 바인딩하여 프로그래밍 방식으로 포커스를 설정할 수 있습니다.
.NET 소스 코드를 사용하여 디버그
복잡한 포커스 문제의 경우 .NET 소스 코드를 사용하여 디버깅하여 프레임워크가 포커스를 처리하는 방식을 이해하는 것이 도움이 될 수 있습니다. 이는 귀중한 통찰력을 제공하고 문제를 정확히 찾아내는 데 도움이 될 수 있습니다.
대안
ViewModel에서 TextBox의 포커스를 설정하는 또 다른 방법은 명령을 사용하여 동작을 수행하는 것입니다. 이 동작은 뷰 또는 ViewModel에서 구현될 수 있으며 버튼 클릭에 바인딩될 수 있습니다. 그러면 위에서 설명한 것과 유사한 기술을 사용하여 동작이 원하는 TextBox에 포커스를 설정할 수 있습니다.
위 내용은 ViewModel에서 WPF의 텍스트 상자에 초점을 프로그래밍 방식으로 설정하려면 어떻게해야합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!