我正在尝试简化一些代码并提高我的可维护性。
我最初正在寻找一种使文本框向左对齐的方法,该方法可以在达到最大值后收缩和扩展至最大值,而无需在网格单元内居中。
所以我开始写一些这样的代码......
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="200" />
</Grid.ColumnDefinitions>
<TextBox Text="Some text"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
Margin="10"
MaxWidth="150" />
</Grid>
(代码清单 1)
这会产生看起来像这样的东西......
(图1)
如您所见,这会将 TextBox 以其最大宽度居中,但它与网格单元格的中心对齐。
那么我可能会像这样改变文本框的水平对齐方式......
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="200" />
</Grid.ColumnDefinitions>
<TextBox Text="Some text"
VerticalAlignment="Center"
HorizontalAlignment="Left"
Margin="10"
MaxWidth="100" />
</Grid>
(代码清单 2)
但不幸的是,这只产生看起来像这样的东西......
(图2)
同样,这是不对的,因为尽管右侧有所有空白空间,但文本框并没有像我想要的那样扩展到其最大宽度 100。
最终,我发现如果将 TextBox 放在嵌套网格中,就可以达到预期的效果。
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="200" />
</Grid.ColumnDefinitions>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="1*"
MaxWidth="120" />
<ColumnDefinition Width="0*" />
</Grid.ColumnDefinitions>
<TextBox Text="Some text"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
Margin="10"
MaxWidth="100" />
</Grid>
</Grid>
(代码清单 3)
这会产生这个......
(图3)
如您所见,嵌套网格填充了整个 200 宽的空间,但文本框填充了左侧的 100,并在右侧留下了空白空间。(如果此窗口可调整大小,它将适当缩小和扩大)
我想将代码清单 3的方法应用到样式或控件模板,因此我可以将它一揽子应用到适用于这种情况的 TextBox。
在一个完美的场景中,我会做类似的事情......
<TextBox Text="Some text"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
Margin="10"
MaxWidth="100"
Style="{StaticResource ExpandingTextBox}" />
(代码清单 4)
并达到与图3相同的结果。
我尝试了以下...
<Style TargetType="{x:Type TextBox}"
x:Key="ExpandingTextBox">
<Setter Property="OverridesDefaultStyle"
Value="True"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="TextBox">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="1*"
MaxWidth="170" />
<ColumnDefinition Width="0*" />
</Grid.ColumnDefinitions>
<ContentPresenter/>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
(代码清单 5)
但这只会导致文本框从我的表单中消失。我不太擅长写这样的模板,所以我有点不知所措。
另外,我刚刚意识到的一件事是嵌套列的宽度 = MaxWidth + 2 x Margin。我不介意在 TextBox 声明中明确设置列宽,但如果它可以是自动的,那就太好了。