4

几天前,我遇到了 Button 中文本的奇怪行为(我猜其他 ContentControls 的行为相同)。让我解释一下情况。我在 App.xaml 中有一个 TextBlock 的样式定义:

<Application.Resources>
    <Style TargetType="{x:Type TextBlock}">
        <Setter Property="Margin" Value="10"/>
    </Style>
</Application.Resources>

在 MainWindow.xaml 中,我有相同的样式定义,它应该覆盖 App.xaml 中定义的样式。我在 Window 中也有 3 个按钮。在第一个按钮中,在按钮内容中明确定义了 TextBlock 控件。对于第二个按钮,我将字符串设置为代码隐藏中的内容。对于第三个按钮,我将一个整数值设置为代码隐藏中的内容。这是 MainWindow.xaml 的代码:

<StackPanel>
    <StackPanel.Resources>
        <Style TargetType="{x:Type TextBlock}">
            <Setter Property="Margin" Value="0"/>
        </Style>
    </StackPanel.Resources>
    <Button Name="Button1">
        <Button.Content>
            <TextBlock Text="Button with text block"/>
        </Button.Content>
    </Button>
    <Button Name="Button2" />
    <Button Name="Button3" />
</StackPanel>

和 MainWindow.xaml.cs:

private void Window_Loaded(object sender, RoutedEventArgs e)
{
    Button2.Content = "Button with string";
    Button3.Content = 16;
}

现在我们看到了什么?正如预期的那样,第一个和第三个按钮中的文本有 0 像素的边距,但第二个按钮中的文本有 10 像素的边距!问题是:为什么第二个按钮有 10px 的边距以及如何为第二个按钮设置零边距(从 App.xaml 中删除样式是不可能的)?

谢谢!

4

2 回答 2

2

当我改变

Button2.Content = "Button with string"; 

Button2.Content = "Button with _string"; 

按钮的边距从 10 变为 0。

这是 WPF 中的一个错误;它已经在Microsoft Connect上进行了报道。

我不是 100% 确定,但我认为您看到的行为是由相同的根本原因引起的。

顺便说一句:正确的行为是按钮 2 和 3 的 Margin=10; 这是因为资源查找是沿着逻辑树执行的,而不是沿着可视树。按钮 2 和 3 中的 TextBlock 不在 StackPanel 的逻辑树中。

于 2012-06-10T06:39:41.937 回答
0

我不能给你一个明确的答案,但我注意到设置字符串和整数之间的区别会导致应用不同的样式。

由于将 Content 设置为需要转换的值会导致应用正确的样式,因此我尝试了以下操作:

private void WindowLoaded(object sender, RoutedEventArgs e)
{
    Button2.Content = new TextHolder("Button with string");
    Button3.Content = 16;
}

public class TextHolder
{
    private readonly string _text;

    public TextHolder(string text)
    {
        _text = text;
    }

    public override string ToString()
    {
        return _text;
    }
}

并且边距现在为 0。我很想了解到底发生了什么。

于 2012-06-09T23:06:42.790 回答