Lier la visibilité du bouton à la propriété Boolean ViewModel dans WPF
Dans le développement MVVM (Model-View-ViewModel), vous devrez peut-être lier la visibilité du bouton à une valeur booléenne stockée dans le ViewModel. Cette tâche simple nécessite du codage XAML et l’utilisation de convertisseurs.
Exemple de code XAML (en supposant que votre bouton existe déjà) :
<code class="language-xml"><Button Content="高级功能" /></code>
Dans cet exemple, AdvancedFormat
est une propriété booléenne dans le ViewModel. Cependant, WPF ne peut pas lier directement les valeurs booléennes à la propriété Visibility. Pour combler cet écart, nous avons besoin d'un BooleanToVisibilityConverter.
Déclarez le convertisseur dans la ressource :
<code class="language-xml"><Window.Resources> <BooleanToVisibilityConverter x:Key="BoolToVis" /> </Window.Resources></code>
Appliquer le convertisseur dans la déclaration du bouton :
Remplacez la liaison de visibilité existante par :
<code class="language-xml"><Button Content="高级功能" Visibility="{Binding Path=AdvancedFormat, Converter={StaticResource BoolToVis}}" /></code>
En ajoutant la ligne Converter={StaticResource BoolToVis}
, vous demandez à la liaison d'utiliser un BooleanToVisibilityConverter pour convertir la propriété booléenne AdvancedFormat
en une valeur de visibilité. Le convertisseur renverra Visible si la propriété est vraie, ou Collapsed si elle est fausse, vous permettant de contrôler la visibilité du bouton en fonction des propriétés du ViewModel.
Ce modèle sépare les préoccupations de la vue (visibilité des boutons) et du modèle (propriétés booléennes), garantissant que la vue est responsable de la détermination de la visibilité en fonction de l'état du modèle.
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!