带有 StaticResource 的 WPF 文本框,用于样式和文本绑定到 ViewModel 的属性
几天来我一直在关注以下问题,也许我误解了一些东西。
我创建一个带有文本框样式设置的 ResourceDictionary 并将其添加到 App.xaml:
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:ZeissVorbereitung">
<Style x:Key="ModernTextbox" TargetType="{x:Type TextBox}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type TextBox}">
<Border CornerRadius="10"
Background="#353340"
Width="100" Height="30">
<Grid>
<Rectangle StrokeThickness="1"/>
<TextBox Margin="1"
Text="{TemplateBinding Text}"
BorderThickness="0"
Background="Transparent"
VerticalContentAlignment="Center"
Padding="5"
Foreground="#CFCFCF"
x:Name="SearchBox"/>
<TextBlock IsHitTestVisible="False"
Text="Type new Entry..."
VerticalAlignment="Center"
HorizontalAlignment="Left"
Margin="10,0,0,0"
FontSize="11"
Foreground="DarkGray"
Grid.Column="1">
<TextBlock.Style>
<Style TargetType="{x:Type TextBlock}">
<Style.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=SearchBox}" Value="">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
<Setter Property="Visibility" Value="Hidden"/>
</Style>
</TextBlock.Style>
</TextBlock>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
然后我在视图中创建一个文本框并成功使用样式:
<TextBox
Grid.Column="0"
Grid.Row="1"
Width="100"
Margin="0,5,0,0"
VerticalAlignment="Top"
Style="{StaticResource ModernTextbox}"
Text="{Binding AddNavigationTextField}"/>
在 ViewModel 中是用于绑定的属性:
private string _addNavigationTextField = "";
public string AddNavigationTextField
{
get => _addNavigationTextField;
set
{
_addNavigationTextField = value;
OnProtertyChanged();
}
}
通常绑定有效,但我不知道如何将样式资源与动态绑定结合起来,这样我就可以使用具有相同样式但不同绑定的多个文本框。感谢您的帮助!
I stucked at followed issue since a few days, perhaps I have misunderstood something.
I create a ResourceDictionary with stylesettings for textboxes and add it to App.xaml:
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:ZeissVorbereitung">
<Style x:Key="ModernTextbox" TargetType="{x:Type TextBox}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type TextBox}">
<Border CornerRadius="10"
Background="#353340"
Width="100" Height="30">
<Grid>
<Rectangle StrokeThickness="1"/>
<TextBox Margin="1"
Text="{TemplateBinding Text}"
BorderThickness="0"
Background="Transparent"
VerticalContentAlignment="Center"
Padding="5"
Foreground="#CFCFCF"
x:Name="SearchBox"/>
<TextBlock IsHitTestVisible="False"
Text="Type new Entry..."
VerticalAlignment="Center"
HorizontalAlignment="Left"
Margin="10,0,0,0"
FontSize="11"
Foreground="DarkGray"
Grid.Column="1">
<TextBlock.Style>
<Style TargetType="{x:Type TextBlock}">
<Style.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=SearchBox}" Value="">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
<Setter Property="Visibility" Value="Hidden"/>
</Style>
</TextBlock.Style>
</TextBlock>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Then I create a textbox in a View and use the Style sucessfully:
<TextBox
Grid.Column="0"
Grid.Row="1"
Width="100"
Margin="0,5,0,0"
VerticalAlignment="Top"
Style="{StaticResource ModernTextbox}"
Text="{Binding AddNavigationTextField}"/>
In the ViewModel is the property for binding:
private string _addNavigationTextField = "";
public string AddNavigationTextField
{
get => _addNavigationTextField;
set
{
_addNavigationTextField = value;
OnProtertyChanged();
}
}
Normaly the bindings works, but I dont know how to combine the Style-Resource with a dynamic Binding, so I could use multiple TextBoxes with the same Style but different bindings. Thank you for your help!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
尝试这样的风格:
我改进了触发器,删除了文本框内部并使用了部分标准风格。
Try style like this:
I improve trigger, remove inside texbox and use part of standart style.