如何在UWP应用程序中保留TextBlock的空格

问题描述 投票:6回答:3

如果您只是将TextBlock中Text属性的值设置为“Example”(请注意,此字符串末尾有3个空格),TextBlock在UI中显示的只是“示例”。

在互联网上搜索解决方案后,我发现有一种方法可以解决这个问题:

<Border BorderThickness="1" 
        BorderBrush="#FFFF0202" 
        HorizontalAlignment="Center" 
        VerticalAlignment="Center">
    <TextBlock x:Name="t1">
        <Run Text="Example&#160;&#160;&#160;"/>
    </TextBlock>
</Border>

上面的代码显示了使用TextBlock的Inline属性和运行文本中的&#160;正确显示了空白。

但是,在我的情况下,我需要在代码隐藏(或通过DataBinding)中设置TextBlock的Text属性,上面的技巧不起作用,它在UI中显示Example&#160;&#160;&#160;

我试图通过数据绑定设置Run的Text属性的值,我认为可以正确显示转义字符,但Run的Text属性不是依赖属性,所以我没有更好的方法来解决这个问题。

(但是我认为使用TextBlock的填充属性也是一个技巧,它应该工作。但还有更好的方法吗?)

c# xaml windows-10 win-universal-app uwp
3个回答
6
投票

首先,Run.Text确实支持数据绑定。

&#160;在数据绑定中无法正确打印的原因是因为它使用的是XML转义字符。

尝试使用(char)160代替 -

public string TestString { get; set; } = "Example" + (char)160 + (char)160 + (char)160;

<TextBlock>
    <Run Text="{x:Bind TestString}" />
</TextBlock>

1
投票

您可以尝试设置xml:space属性以保留在XAML中

<TextBox Name="t1"
         xml:space="preserve"
         Text="Example   " />

0
投票

我在UWP中有一个Listview.ItemTemplate的解决方案。

<ListBox.ItemTemplate>
     <DataTemplate>
          <StackPanel Orientation="Horizontal">
               <TextBlock xml:space="preserve"><Run Text="{Binding ID}"></Run><Run> </Run><Run Text="{Binding name}"></Run><Run> </Run><Run Text="{Binding ipAdress}"></Run></TextBlock>
           </StackPanel>
      </DataTemplate>
</ListBox.ItemTemplate>
  • 请注意,文本块的属性为xml:space =“preserve”。
  • 空格使用run元素<Run> </Run>设置。
  • 使用此解决方案,您必须确保在代码编辑器中一行定义元素和元素,否则将包含其中包含的可用空间。
© www.soinside.com 2019 - 2024. All rights reserved.