Wpf 为我的组合框样式指定键名称

Wpf 为我的组合框样式指定键名称,wpf,xaml,wpf-controls,Wpf,Xaml,Wpf Controls,我修改了一个组合框样式,下面列出了该样式。它工作正常,但是,该样式适用于我的项目中的所有组合框。换句话说,当我从工具箱中拉出一个组合框时,它会自动设置样式。我想做的只是用样式为某些组合框设计样式,而不是全部。当然,我必须使用一个键名将样式应用于每个控件。我的问题是,如何修改样式,以便我可以通过一个键名“myComboBox”来引用它。谢谢你的帮助 我的资源字典中的样式: <ControlTemplate x:Key="ComboBoxToggleButton" TargetType

我修改了一个组合框样式,下面列出了该样式。它工作正常,但是,该样式适用于我的项目中的所有组合框。换句话说,当我从工具箱中拉出一个组合框时,它会自动设置样式。我想做的只是用样式为某些组合框设计样式,而不是全部。当然,我必须使用一个键名将样式应用于每个控件。我的问题是,如何修改样式,以便我可以通过一个键名“myComboBox”来引用它。谢谢你的帮助

我的资源字典中的样式:

    <ControlTemplate x:Key="ComboBoxToggleButton" TargetType="{x:Type ToggleButton}">
    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition />
            <ColumnDefinition Width="10" />
        </Grid.ColumnDefinitions>
        <Border
                x:Name="Border" 
                Grid.ColumnSpan="2"
                CornerRadius="0"
                Background="Black" 
                BorderBrush="Black"
                BorderThickness="0" />
        <Border 
                Grid.Column="0"
                CornerRadius="0,0,0,0" 
                Margin="1" 
                Background="Black" 
                BorderBrush="Black"
                BorderThickness="0,0,0,0" />
        <Path 
              x:Name="Arrow"
              Grid.Column="1"     
              Fill="#404040"
              HorizontalAlignment="Center"
              VerticalAlignment="Center"
              Data="M 0 0 L 4 4 L 8 0 Z"/>
    </Grid>
    <ControlTemplate.Triggers>
        <Trigger Property="ToggleButton.IsMouseOver" Value="true">
            <Setter TargetName="Border" Property="Background" Value="#808080" />
        </Trigger>
        <Trigger Property="ToggleButton.IsChecked" Value="true">
            <Setter TargetName="Border" Property="Background" Value="#E0E0E0" />
        </Trigger>
        <Trigger Property="IsEnabled" Value="False">
            <Setter TargetName="Border" Property="Background" Value="#EEEEEE" />
            <Setter TargetName="Border" Property="BorderBrush" Value="#AAAAAA" />
            <Setter Property="Foreground" Value="#888888"/>
            <Setter TargetName="Arrow" Property="Fill" Value="#888888" />
        </Trigger>
    </ControlTemplate.Triggers>
</ControlTemplate>

<ControlTemplate x:Key="ComboBoxTextBox" TargetType="{x:Type TextBox}">
    <Border x:Name="PART_ContentHost" Focusable="False" Background="{TemplateBinding Background}" />
</ControlTemplate>

<Style x:Key="{x:Type ComboBox}" TargetType="{x:Type ComboBox}">
    <Setter Property="SnapsToDevicePixels" Value="true"/>
    <Setter Property="OverridesDefaultStyle" Value="true"/>
    <Setter Property="ScrollViewer.HorizontalScrollBarVisibility" Value="Auto"/>
    <Setter Property="ScrollViewer.VerticalScrollBarVisibility" Value="Auto"/>
    <Setter Property="ScrollViewer.CanContentScroll" Value="true"/>
    <Setter Property="MinWidth" Value="0"/>
    <Setter Property="MinHeight" Value="20"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type ComboBox}">
                <Grid>
                    <ToggleButton 
                            Name="ToggleButton" 
                            Template="{StaticResource ComboBoxToggleButton}" 
                            Grid.Column="2" 
                            Focusable="false"
                            IsChecked="{Binding Path=IsDropDownOpen,Mode=TwoWay,RelativeSource={RelativeSource TemplatedParent}}"
                            ClickMode="Press">
                    </ToggleButton>
                    <ContentPresenter
                            Name="ContentSite"
                            IsHitTestVisible="False" 
                            Content="{TemplateBinding SelectionBoxItem}"
                            ContentTemplate="{TemplateBinding SelectionBoxItemTemplate}"
                            ContentTemplateSelector="{TemplateBinding ItemTemplateSelector}"
                            Margin="1,0,11,0" 
                            VerticalAlignment="Stretch"
                            HorizontalAlignment="Left" />
                    <TextBox x:Name="PART_EditableTextBox"
                            Style="{x:Null}" 
                            Template="{StaticResource ComboBoxTextBox}" 
                            HorizontalAlignment="Left" 
                            VerticalAlignment="Center" 
                            Margin="1,0,11,0"
                            Focusable="True" 
                            Background="Transparent"
                            Visibility="Hidden"
                            IsReadOnly="{TemplateBinding IsReadOnly}"/>
                    <Popup 
                            Name="Popup"
                            Placement="Bottom"
                            IsOpen="{TemplateBinding IsDropDownOpen}"
                            AllowsTransparency="True" 
                            Focusable="False"
                            PopupAnimation="Slide">
                        <Grid 
                                  Name="DropDown"
                                  SnapsToDevicePixels="True"                
                                  MinWidth="{TemplateBinding ActualWidth}"
                                  MaxHeight="{TemplateBinding MaxDropDownHeight}">
                            <Border 
                                    x:Name="DropDownBorder"
                                    Background="Black"
                                    BorderThickness="1"
                                    BorderBrush="#888888"/>
                            <ScrollViewer Margin="4,6,4,6" SnapsToDevicePixels="True">
                                <StackPanel IsItemsHost="True" KeyboardNavigation.DirectionalNavigation="Contained" />
                            </ScrollViewer>
                        </Grid>
                    </Popup>
                </Grid>
                <ControlTemplate.Triggers>
                    <Trigger Property="HasItems" Value="false">
                        <Setter TargetName="DropDownBorder" Property="MinHeight" Value="95"/>
                    </Trigger>
                    <Trigger Property="IsEnabled" Value="false">
                        <Setter Property="Foreground" Value="#888888"/>
                    </Trigger>
                    <Trigger Property="IsGrouping" Value="true">
                        <Setter Property="ScrollViewer.CanContentScroll" Value="false"/>
                    </Trigger>
                    <Trigger SourceName="Popup" Property="Popup.AllowsTransparency" Value="true">
                        <Setter TargetName="DropDownBorder" Property="CornerRadius" Value="0"/>
                        <Setter TargetName="DropDownBorder" Property="Margin" Value="0,0,0,0"/>
                    </Trigger>
                    <Trigger Property="IsEditable"
                                Value="true">
                        <Setter Property="IsTabStop" Value="false"/>
                        <Setter TargetName="PART_EditableTextBox" Property="Visibility" Value="Visible"/>
                        <Setter TargetName="ContentSite" Property="Visibility" Value="Hidden"/>
                    </Trigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
    <Style.Triggers>
    </Style.Triggers>
</Style>

<!-- SimpleStyles: ComboBoxItem -->

<Style x:Key="{x:Type ComboBoxItem}" TargetType="{x:Type ComboBoxItem}">
    <Setter Property="SnapsToDevicePixels" Value="true"/>
    <Setter Property="OverridesDefaultStyle" Value="true"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type ComboBoxItem}">
                <Border Name="Border" Padding="0" SnapsToDevicePixels="true">
                    <ContentPresenter />
                </Border>
                <ControlTemplate.Triggers>
                    <Trigger Property="IsHighlighted" Value="true">
                        <Setter TargetName="Border" Property="Background" Value="#888888"/>
                    </Trigger>
                    <Trigger Property="IsEnabled" Value="false">
                        <Setter Property="Foreground" Value="#888888"/>
                    </Trigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

样式提供唯一的
x:Key

<Style x:Key="myComboBoxStyle" TargetType="{x:Type ComboBoxItem}">

你的问题是你正在使用的钥匙。 这: x:Key=“{x:Type组合框}”
将其更改为不包含任何花括号或x:type的其他字符串。

当您指定
x:Key
时,它会创建一个字符串。你想要的是明确的风格。 你需要做的是改变这一行

<Style x:Key="{x:Type ComboBox}" TargetType="{x:Type ComboBox}">

将来

<Style x:Key="myComboBoxStyle" TargetType="{x:Type ComboBox}">

此外,ComboBoxItem上还有一个隐式样式。您将要更改以下内容:

将是:

<Style x:Key="myComboBoxItem" TargetType="{x:Type ComboBoxItem}">

最后,您需要将ComboBox项目样式设置为ComboBox的项目样式。 将其添加到组合框样式中

<Setter Property="ItemContainerStyle" Value="{StaticResource myComboBoxItem}"/>


我在资源字典中添加了样式和唯一键作为一行,但是,即使未应用样式,样式仍然应用于项目中的所有组合框控件。一行?您所需要做的就是将键从“{x:Type ComboBoxItem}”更改为例如“mycomboxStyle”。感谢所有参与的人。这似乎是最完整的答案,现在正在起作用。@namg_engr:这个答案和我的有什么区别?
<Setter Property="ItemContainerStyle" Value="{StaticResource myComboBoxItem}"/>