TextBlock 的run元素

这里第一个run的content滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。 和第二个的Text有什么区别?

<TextBlock x:Name="textblock"  
                       Width="320" 
                       Height="100" 
                       FontSize="15" 
                       FontFamily="微软雅黑" 
                       FontWeight="Black" 
                       FontStretch="Condensed" 
                       Foreground="#dddddd" 
                       Background="Teal" 
                       TextAlignment="Center" 
                       TextWrapping="Wrap" 
                       TextTrimming="CharacterEllipsis" 
                       Margin="10" Padding="5"
                       HorizontalAlignment="Left" 
                       VerticalAlignment="Center" 
                       LineHeight="30" 
                       ToolTip="《临江仙·滚滚长江东逝水》">
		<Run Foreground="#CDB632" TextDecorations="Underline">
			滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。
		</Run>
		<Run Text="白发渔樵江渚上,惯看秋月春风。一壶浊酒喜相逢。古今多少事,都付笑谈中。 ">
		</Run>
            </TextBlock>  

在XAML中,设置Run元素的文本内容可以通过直接在Run标签内放置文本,或者使用Text属性来实现。你提供的示例中展示了这两种不同的方法:

第一个Run元素

<Run Foreground="#CDB632" TextDecorations="Underline">
    滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。
</Run>

这里,文本直接放置在Run标签内部。这种方式更直观,尤其是当你想要快速设置简单的文本内容时。此外,这种方式能够让你更容易地看到文本的内容,特别是当文本较短时。

第二个Run元素

<Run Text="白发渔樵江渚上,惯看秋月春风。一壶浊酒喜相逢。古今多少事,都付笑谈中。 ">
</Run>

这里,文本是通过Text属性设置的。这种方式在处理动态文本或需要通过绑定设置文本内容时非常有用。使用Text属性可以让XAML看起来更加整洁,尤其是当文本内容较长或者需要国际化支持时。

区别

实际上,从功能角度看,这两种方法没有本质的区别——它们都是用于设置Run元素的文本内容的。选择哪一种方式主要取决于个人偏好、文本内容的长度、以及是否需要动态绑定文本。

  • 直接在Run标签内放置文本更符合直观的编辑习惯,特别是在文本相对静态时。
  • 使用Text属性设置文本可能使XAML结构更清晰,特别是在处理动态文本或长文本时。

总的来说,这两种方式都是有效的,你可以根据具体情况和个人喜好来选择使用哪一种。

这里的内容是Text属性隐式赋值吗?

<Run Foreground="#CDB632" TextDecorations="Underline">
    滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。
</Run>

在XAML中,当你直接在Run元素(或任何其他内容控件)标签内放置文本时,这种方式可以被看作是对该元素的Content属性(对于Run元素来说特指Text属性)的隐式赋值。不过,值得注意的是,Run元素没有名为Content的属性,它使用的是Text属性来保存文本内容。因此,更准确地说,这是对RunText属性的隐式赋值。

Run元素是专门用于TextBlockParagraph等控件内部,用来包含流式文本的。在这种情况下,Run内部的文本直接被视作它的Text属性的值。这是XAML的一种便捷语法,允许你以直观的方式添加文本内容,而不需要显式地写出Text=...

因此,对于你的示例:

<Run Foreground="#CDB632" TextDecorations="Underline">
    滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。
</Run>

这里的文本"滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。"是被隐式赋值给RunText属性的。这种写法让XAML代码更加简洁和易读,特别是当需要设置的文本较长时。

显示的赋值文本呢?


在XAML中,显示地为Run元素赋值文本内容,意味着你将使用Text属性来指定文本。这是一种更明确的方法,尤其适用于当文本内容是通过绑定或其他表达式获得时。这种方式清晰地表明了文本值是作为属性值被设置的。

以下是使用显示属性赋值方式为Run元素设置文本的示例:

<Run Text="滚滚长江东逝水,浪花淘尽英雄。是非成败转头空。青山依旧在,几度夕阳红。" Foreground="#CDB632" TextDecorations="Underline" />

在这个示例中,Text属性被显式地设置为一段文本。这与直接在Run元素标签内放置文本形成对比,后者是隐式地设置Text属性的值。

选择使用隐式赋值还是显示赋值

  • 隐式赋值:当直接在Run标签内添加文本时,这种方式更接近于HTML或其他标记语言中的内容表示方式,对于简单的静态文本而言非常直观和方便。

  • 显示赋值:通过Text属性显式设置文本时,代码的意图更明确,尤其是在文本内容需要通过数据绑定或资源获取的情况下。例如:

    <Run Text="{Binding Path=SomeTextProperty}" />
    

    或者

    <Run Text="{StaticResource SomeTextKey}" />
    

在实际开发中,根据具体情况和个人偏好选择使用隐式赋值还是显示赋值。对于简单的、直接的文本内容,直接在Run标签内放置文本(隐式赋值)通常更简洁。而对于需要数据绑定或使用资源的复杂场景,使用Text属性(显示赋值)可能更适合。

总结


是的,您完全正确。

<Run>这是一段文本内容</Run>

这种在Run元素内直接放置文本内容的写法,实际上就是在隐式地为Run元素的Text属性赋值。

虽然代码中没有直接使用Text属性,但是WPF的XAML解析器会自动将该Run元素内的文本内容赋给Text属性。

所以上面的XAML实际上等同于:

<Run Text="这是一段文本内容" />

通过在元素内放置文本的这种隐式赋值方式,可以让XAML看起来更加简洁直观,尤其是对于静态文本内容而言。但如果需要将动态文本或通过绑定获取的文本赋给Text属性,那么就需要使用显式的属性赋值语法了。

总的来说,您完全正确地理解了这种在元素内放置文本内容的写法实际上是一种隐式的Text属性赋值方式。

相关推荐

  1. TextBlock run元素

    2024-03-31 21:22:02       44 阅读
  2. C#WPF控件TextBlock、Label以及与TextBox区别

    2024-03-31 21:22:02       37 阅读
  3. docker run复杂使用

    2024-03-31 21:22:02       25 阅读
  4. npm run dev 与npm run serve区别

    2024-03-31 21:22:02       53 阅读
  5. npm run serve和npm run dev区别

    2024-03-31 21:22:02       54 阅读
  6. Crow:run流程1 准备阶段

    2024-03-31 21:22:02       61 阅读
  7. Docker:docker run --rm 选项

    2024-03-31 21:22:02       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-31 21:22:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-31 21:22:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-31 21:22:02       82 阅读
  4. Python语言-面向对象

    2024-03-31 21:22:02       91 阅读

热门阅读

  1. 探索前端开发中的路径:./、../、@/ 等详解

    2024-03-31 21:22:02       36 阅读
  2. 生产环境数据处理单sql编写

    2024-03-31 21:22:02       35 阅读
  3. Dockerfile中DSL语法

    2024-03-31 21:22:02       35 阅读
  4. python之@overload

    2024-03-31 21:22:02       45 阅读
  5. Spring Boot(版本:3.2.4)入门

    2024-03-31 21:22:02       39 阅读
  6. 队列的基本概念

    2024-03-31 21:22:02       38 阅读
  7. Android TV 应用中的遥控器按键事件处理

    2024-03-31 21:22:02       43 阅读
  8. FastAPI+React全栈开发11 开始使用FastAPI

    2024-03-31 21:22:02       40 阅读