[英]How do I make clickable buttons inside ListViewItem with WinRT?
我正在嘗試創建一個自定義控件,其中包含一些帶有+/-按鈕的列表。 這是我的XAML代碼:
<UserControl.Resources>
<Style TargetType="ListViewItem">
<Setter Property="HorizontalContentAlignment" Value="Stretch" />
</Style>
<DataTemplate x:Key="lvheader">
<Grid Background="#A0BBBBBB" Height="32">
<TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Margin="5,2" FontWeight="Medium" FontSize="14" Text="{Binding}" />
</Grid>
</DataTemplate>
<DataTemplate x:Key="lvitem">
<Grid>
<StackPanel Orientation="Horizontal">
<Button>+</Button>
<Button>-</Button>
<TextBlock VerticalAlignment="Center" TextAlignment="Left" Text="{Binding Path=Name}" />
</StackPanel>
<TextBlock VerticalAlignment="Center" TextAlignment="Right" Text="{Binding Path=Count}" />
</Grid>
</DataTemplate>
</UserControl.Resources>
<Grid Background="#E0020210">
<Border CornerRadius="6" Padding="5" Background="#242424" BorderBrush="#CBCBCB" BorderThickness="1" Width="850" Height="450" VerticalAlignment="Center" HorizontalAlignment="Center">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="auto" />
</Grid.RowDefinitions>
<ListView SelectionMode="None" Name="imgStyles" Header="Image Style" HeaderTemplate="{StaticResource lvheader}" ItemTemplate="{StaticResource lvitem}" ItemsSource="{Binding Path=GenericTags}" />
<ListView SelectionMode="None" Name="imgCopyrights" Grid.Column="1" Header="Image Copyright" HeaderTemplate="{StaticResource lvheader}" ItemTemplate="{StaticResource lvitem}" ItemsSource="{Binding Path=CopyrightTags}" />
<ListView SelectionMode="None" Name="imgCharacters" Grid.Column="2" Header="Image Character" HeaderTemplate="{StaticResource lvheader}" ItemTemplate="{StaticResource lvitem}" ItemsSource="{Binding Path=CharacterTags}" />
<TextBlock VerticalAlignment="Center" Text="Rating:" Grid.Row="1" />
<ComboBox Margin="4" Grid.Row="1" Grid.Column="1" Name="rating" ItemsSource="{Binding Path=AllRatings}" />
<Button Margin="2" HorizontalAlignment="Stretch" Grid.Column="2" Grid.Row="1" Content="Search!" Click="Button_Click" />
<Grid Grid.RowSpan="2" Grid.ColumnSpan="3" Name="pw" Background="#EE111111" Visibility="Collapsed">
<StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
<ProgressRing Width="96" Height="96" Background="Transparent" IsActive="True" />
<TextBlock Text="Loading..." TextAlignment="Center" FontSize="15" />
</StackPanel>
</Grid>
</Grid>
</Border>
</Grid>
使用此設置,我無法單擊[+] / [-]按鈕。 除非我單擊按鈕的邊框,否則將選擇ListViewItem
。 然后它似乎起作用。
我記得很久以前解決了這個問題,但是我不知道我是如何做到的。 處理此問題的最佳方法是什么?
@ CherryBu-MSFT我有點困惑。 添加命令實際上會改變按鈕的行為嗎?
抱歉,回復延遲。
根據您上面的問題,您可以創建作為“命令”的公共方法並將其綁定到您的按鈕,以便在觸發按鈕單擊事件時,將執行視圖模型中的命令。
更多信息,您可以參考此線程 。
我認為您只需要更改當前的DataRepeater。 如果您要在“有序列表”中顯示按鈕,我認為ListView不是正確的選擇。 (我只是在這里猜測)
嘗試過ItemsControl控件嗎? 如果我沒記錯的話,它是ListView使用的核心組件。 但是主要優點是,盡管它仍然具有可綁定的ItemsSource屬性,但它不提供任何奇特的“選擇”行為。
請參閱文檔 。
但是,對您要實現的目標的更多見解將對您提供正確的答案有很大的幫助。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.