WPF样式中TargetType 属性 (Property) 和 x:Key 属性 (Attribute)

如第一个示例所示,如果将 TargetType 属性设置为 TextBlock 而不为样式分配 x:Key,样式就会应用于所有 TextBlock 元素。这种情况下,x:Key 隐式设置为 {x:Type TextBlock}。这意味着,如果将 x:Key 值显式设置为 {x:Type TextBlock} 之外的任何值,Style 就不会自动应用于所有 TextBlock 元素。此时,必须通过使用 x:Key 值,将样式显式应用于 TextBlock 元素。如果样式位于资源部分,并且未设置样式的 TargetType 属性,则必须提供 x:Key。
 
除了提供 x:Key 的默认值之外,TargetType 属性还指定要应用 setter 属性的类型。如果未指定 TargetType,则必须通过语法 Property="ClassName.Property",用类名限定 Setter 对象的属性。例如,必须将 Property 设置为 "TextBlock.FontSize" 或 "Control.FontSize",而不要设置 Property="FontSize"。

转载于:https://www.cnblogs.com/Im-Victor/p/10680486.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如下是一个标准的 ControlTemplate,它的 TargetType 为 ContentControl,在 WPF 使用: ```xml <ControlTemplate TargetType="{x:Type ContentControl}"> <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}"> <ContentPresenter Content="{TemplateBinding Content}" ContentTemplate="{TemplateBinding ContentTemplate}"/> </Border> </ControlTemplate> ``` 这个 ControlTemplate 定义了一个 Border 元素,它的背景、边框画刷和边框粗细都是由 ContentControl 绑定的。它的子元素是 ContentPresenter,它的内容、内容模板都是由 ContentControl 绑定的。 ### 回答2: 一个符合标准的WPF的ControlTemplate,其TargetType为ContentControl,可以被如下定义和实现: ```xml <Style TargetType="{x:Type ContentControl}"> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="{x:Type ContentControl}"> <Border Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}"> <ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Content="{TemplateBinding Content}" /> </Border> </ControlTemplate> </Setter.Value> </Setter> </Style> ``` 这个ControlTemplate的目标类型是ContentControl,使用了一个Border作为容器,用于设置边框背景和边框样式。内部有一个ContentPresenter,用于呈现ContentControl的内容。ContentPresenter的水平对齐和垂直对齐方式都设置为居,以确保内容在容器显示。 在实际使用时,可以将此ControlTemplate应用于任何TargetType为ContentControl的控件,例如: ```xml <ContentControl Template="{StaticResource StandardContentControlTemplate}"> <!-- 这里放置需要呈现的内容 --> </ContentControl> ``` 通过这个标准的ControlTemplate,可以统一ContentControl的外观样式,增强应用界面的一致性和美观性。 ### 回答3: 当我们在WPF使用ControlTemplate时,"TargetType="{x:Type ContentControl}"定义的模板将适用于ContentControl及其所有派生类的控件。 以下是一个WPF标准的,TargetType="{x:Type ContentControl}"的控件模板的示例: ```xml <ControlTemplate TargetType="{x:Type ContentControl}"> <Border BorderBrush="Black" BorderThickness="1" Background="LightGray" CornerRadius="5"> <!-- 内容控件的内容将放置在这里 --> <ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" /> </Border> </ControlTemplate> ``` 在这个示例,我们使用了一个Border控件来包裹ContentControl的内容。该Border具有黑色边框、灰色背景和圆角边框。 ContentPresenter用于呈现ContentControl的内容,它被设置为水平和垂直居,使得内容在Border显示。 使用这个模板时,可以通过将模板应用到ContentControl的Style来覆盖默认模板。例如: ```xml <ContentControl Content="Hello, World!" Style="{StaticResource MyContentControlStyle}" /> ``` 其,MyContentControlStyle是已定义的样式,它引用了上述的标准模板。 这样,ContentControl将使用定义的控件模板进行呈现,显示带有边框和背景的内容。 希望这个回答能够对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值