设置Windows Phone 8.1 UserControl的样式



我在Windows Phone 8.1项目中有以下UserControl:

<UserControl
x:Name="AuditItem"
x:Class="WindowsPhone.OverviewAuditItem"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:WindowsPhone"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
Height="Auto" 
Tapped="AuditItem_Tapped"
Style="{StaticResource MyUserControlStyle}">
<Grid x:Name="contentGrid">
    <Grid.RowDefinitions>
        <RowDefinition Height="Auto"></RowDefinition>
    </Grid.RowDefinitions>
    <StackPanel Grid.Row="0" Height="160" >
        <TextBlock x:Name="textAuditName" Margin="10,10,0,0" TextWrapping="Wrap" Text="Audit Name" VerticalAlignment="Top"/>
        <TextBlock x:Name="textCreatedDate" HorizontalAlignment="Left" TextWrapping="Wrap" Text="TextBlock" VerticalAlignment="Center"/>
        <TextBlock x:Name="textLastOpened" HorizontalAlignment="Left" TextWrapping="Wrap" Text="TextBlock" VerticalAlignment="Center" />
        <!--<Button Content="This styling works but the UC style doesn't"
                Height="100"
                Style="{StaticResource MyButtonStyle}" />-->
        <StackPanel Orientation="Horizontal" Grid.Column="2">
            <TextBlock x:Name="textDeadline" HorizontalAlignment="Left" TextWrapping="Wrap" Text="TextBlock" VerticalAlignment="Center" Grid.Column="2"/>
            <Grid x:Name="blockOverdue" Margin="10,0,0,0">
                <Image Source="PNGs/alerticon.png" Stretch="None" HorizontalAlignment="Center" />
            </Grid>
        </StackPanel>
        <TextBlock x:Name="textTemplate" HorizontalAlignment="Left" TextWrapping="Wrap" Text="TextBlock" VerticalAlignment="Center"   Grid.Column="3"/>
    </StackPanel>
</Grid>

我已经在 App.xaml 文件中定义了我的样式:

<Style TargetType="local:OverviewAuditItem" x:Key="MyUserControlStyle" >
            <Setter Property="Background" Value="Blue" />
            <Setter Property="FontFamily" Value="Arial Black" />
            <Setter Property="FontSize" Value="36" />
        </Style>

我知道样式正在被"找到",因为我没有收到"无法解析资源"错误(如果我更改测试的名称,我确实会收到该错误)

不过,没有应用任何样式。我希望 UserControl 背景为蓝色,并且控件上的所有文本块都使用文本大小和系列。我对此很陌生,所以也许它不是这样工作的。

的问题:它应该像我假设的那样工作吗?如果是,那么我哪里出错了,如果不是,那么如何将样式应用于用户控件?

作为测试 - 你可以看到我有一个注释掉的按钮,这个的样式确实有效。

所以你的风格针对的是错误的Type,以获得我认为你所要求的东西,你需要这样做:

这面向使用 MyUserControlStyle 键的任何用户控件

<Style TargetType="UserControl" x:Key="MyUserControlStyle" >
     <Setter Property="Background" Value="Blue" />
</Style>

这针对页面上的所有文本块 -请注意此处没有键,因此它针对所有textblocks。若要定位单个TextBlocks请添加键并在 TextBlocks Style 属性中实现它

<Style TargetType="TextBlock" >
     <Setter Property="FontFamily" Value="Arial Black" />
     <Setter Property="FontSize" Value="36" />
</Style>

有关 WPF 样式的详细信息,请查看此处

最新更新