3 回答

TA貢獻1818條經驗 獲得超8個贊
還應該注意的是,堆棧面板不可操縱,因此它永遠都不會獲得焦點(如果您/ really /希望使其聚焦,則將其設置為Focusable = True)。但是,在這種情況下要記住的關鍵是Stackpanel是TreeViewItem的子級,在這種情況下,它是ItemContainer。正如Micah所建議的那樣,調整itemcontainerstyle是一個好方法。
您可能可以使用DataTemplates進行操作,諸如datatriggers之類的事情將使用RelativeSouce標記擴展來查找listviewitem

TA貢獻1802條經驗 獲得超5個贊
最簡單的方法是為“ ItemContainerStyle”而不是“ ItemTemplate”屬性提供模板。在下面的代碼中,我創建了2個數據模板:一個用于“未選中”狀態,一個用于“選中”狀態。然后,我為“ ItemContainerStyle”創建一個模板,該模板是包含該項目的實際“ ListBoxItem”。我將默認的“ ContentTemplate”設置為“ Unselected”狀態,然后提供一個觸發器,當“ IsSelected”屬性為true時,該觸發器將交換出模板。(注意:為簡單起見,我將后面代碼中的“ ItemsSource”屬性設置為字符串列表)
<Window.Resources>
<DataTemplate x:Key="ItemTemplate">
<TextBlock Text="{Binding}" Foreground="Red" />
</DataTemplate>
<DataTemplate x:Key="SelectedTemplate">
<TextBlock Text="{Binding}" Foreground="White" />
</DataTemplate>
<Style TargetType="{x:Type ListBoxItem}" x:Key="ContainerStyle">
<Setter Property="ContentTemplate" Value="{StaticResource ItemTemplate}" />
<Style.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="ContentTemplate" Value="{StaticResource SelectedTemplate}" />
</Trigger>
</Style.Triggers>
</Style>
</Window.Resources>
<ListBox x:Name="lstItems" ItemContainerStyle="{StaticResource ContainerStyle}" />
- 3 回答
- 0 關注
- 757 瀏覽
添加回答
舉報