Maison > développement back-end > C++ > Comment définir le focus sur une TextBox WPF à partir de son ViewModel ?

Comment définir le focus sur une TextBox WPF à partir de son ViewModel ?

Mary-Kate Olsen
Libérer: 2025-01-26 02:02:09
original
490 Les gens l'ont consulté

How to Set Focus on a WPF TextBox from its ViewModel?

Définir le focus TextBox depuis ViewModel dans WPF

Dans le développement d'applications WPF, il est parfois nécessaire de définir le focus d'un contrôle spécifique à partir du ViewModel. Ceci peut être réalisé en utilisant une combinaison de propriétés attachées et de techniques de liaison.

Évitez de référencer directement les éléments de l'interface utilisateur dans ViewModel

Dans l'exemple de code, cs.txtCompanyID accède directement aux éléments de l'interface utilisateur dans la vue. Il n'est généralement pas recommandé de référencer directement les éléments de l'interface utilisateur dans la couche ViewModel, car cela entraînerait un couplage étroit du code avec l'interface utilisateur et réduirait la testabilité.

Utiliser les attributs attachés pour la gestion du focus

Une meilleure approche consiste à utiliser une propriété attachée, qui peut être liée à une propriété ViewModel. Dans ce cas, nous pouvons créer une propriété attachée appelée IsFocused qui accepte une valeur booléenne indiquant si le contrôle associé doit avoir le focus.

Ce qui suit est un exemple d'implémentation de la IsFocused propriété attachée :

<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>
Copier après la connexion

Lier des propriétés supplémentaires à ViewModel

Une fois que vous avez la propriété attachée, vous pouvez la lier à une propriété ViewModel qui indique si le contrôle doit avoir le focus. À votre avis (XAML), vous pouvez lier la propriété IsFocused à la propriété ViewModel correspondante :

<code class="language-xml"><TextBox local:FocusExtension.IsFocused="{Binding IsUserNameFocused}"></TextBox></code>
Copier après la connexion

Débogage à l'aide du code source .NET

Si vous rencontrez des problèmes pour définir le focus, envisagez de déboguer le code source .NET pour avoir un aperçu de son comportement. Ici, vous pouvez observer comment le framework sous-jacent gère le focus et éventuellement identifier les différences dans votre implémentation personnalisée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal