麻烦造型数据绑定WPF ComboBoxItem

时间:2011-09-27 17:05:20

标签: c# wpf

我有一个ComboBox,绑定到DataTable。我正在尝试在列表顶部添加一个额外的ComboBoxItem,我可以在其中放置一个链接来自定义列表。目前我只是在我的DataTable的顶部插入一个虚拟行,然后在ComboBox上使用DataTrigger使其正确显示。但是,我没有得到正确的结果。

我尝试了两种方法。在第一个中,我的DataTrigger用ControlTemplate替换了虚拟项目,ControlTemplate包含一个TextBlock。

<ComboBox IsEditable="True" Name="comboWell" ItemsSource="{Binding}" DisplayMemberPath="wellId">
    <ComboBox.ItemContainerStyle>
        <Style TargetType="{x:Type ComboBoxItem}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding wellId}" Value="(settings)">
                    <Setter Property="Template">
                        <Setter.Value>
                            <ControlTemplate TargetType="ComboBoxItem">
                                <TextBlock Text="Customize..." />
                            </ControlTemplate>
                        </Setter.Value>
                    </Setter>
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </ComboBox.ItemContainerStyle>
</ComboBox>

结果看起来正确,但该项目上没有鼠标悬停突出显示。列表的其余部分工作正常,但当我将鼠标悬停在其上时,该项目根本没有反应。我已经尝试添加额外的触发器和样式来应用鼠标悬停效果,但我没有变化。

我尝试的第二种方法只是改变项目的外观而不是用ControlTemplate完全替换它。

<ComboBox IsEditable="True" Name="comboWell" ItemsSource="{Binding}" DisplayMemberPath="wellId">
    <ComboBox.ItemContainerStyle>
        <Style TargetType="{x:Type ComboBoxItem}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding wellId}" Value="(settings)">
                    <Setter Property="Content" Value="Customize..." />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </ComboBox.ItemContainerStyle>
</ComboBox>

这个功能类似于常规列表项,鼠标悬停工作正常。但是,该项目为空白。原始文本和我尝试在DataTrigger中设置的文本都没有。没有错误,只是一个空列表项。

有没有更好的方法来实现这一目标?

1 个答案:

答案 0 :(得分:2)

删除DisplayMemberPath并将默认内容添加到样式

<ComboBox IsEditable="True" Name="comboWell" ItemsSource="{Binding }">
    <ComboBox.ItemContainerStyle>
        <Style TargetType="{x:Type ComboBoxItem}">
            <Setter Property="Content" Value="{Binding wellId}" />
            <Style.Triggers>
                <DataTrigger Binding="{Binding wellId}" Value="(settings)">
                    <Setter Property="Content" Value="Customize..." />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </ComboBox.ItemContainerStyle>
</ComboBox>

DisplayMemberPath实际上是一种快捷方式,表示项目模板应该只是一个TextBlock,其文本绑定到DisplayMemberPath项目,我猜它是覆盖了你在样式中的所有内容。