1

詳細テーブルを持つデータがいくつかあります。データを ListView に表示したい。元のリストのアイテムを選択したときに、ネストされた ListView として詳細データが表示されるようにします。データバインディングを機能させる方法がわかりません。

これが私がこれまでに持っているものです(問題はです{Binding Path=FK_History_HistoryItems}):

<ListView Name="lstHistory" ItemsSource="{Binding Source={StaticResource History}}" SelectionChanged="lstHistory_SelectionChanged">
    <ListView.View>
        <GridView>
            <GridViewColumn DisplayMemberBinding="{Binding Path=Name}" Header="Name" Width="100" />
            <GridViewColumn DisplayMemberBinding="{Binding Path=Description}" Header="Description" Width="150" />
            <GridViewColumn DisplayMemberBinding="{Binding Path=Total, Converter={StaticResource moneyConvert}}" Header="Total" Width="100" />
            <GridViewColumn DisplayMemberBinding="{Binding Converter={StaticResource categoryAggregate}}" Header="Categories" Width="100" />
        </GridView>
    </ListView.View>
    <ListView.Resources>
        <Style TargetType="{x:Type ListViewItem}">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type ListViewItem}">
                        <Border>
                            <StackPanel>
                                <Border Name="presenter"
                                        Background="{TemplateBinding Background}"
                                        BorderBrush="{TemplateBinding BorderBrush}"
                                        BorderThickness="{TemplateBinding BorderThickness}"
                                        Padding="{TemplateBinding Padding}">
                                    <GridViewRowPresenter />
                                </Border>
                                <Border Name="details" Visibility="Collapsed" Margin="5"
                                        BorderBrush="Black" BorderThickness="2">
                                    <StackPanel Margin="5">
                                        <ListView ItemsSource="{Binding Path=FK_History_HistoryItems}">
                                            <ListView.View>
                                                <GridView>
                                                    <GridViewColumn DisplayMemberBinding="{Binding Path=Ammount}" Header="Ammount" Width="100" />
                                                    <GridViewColumn DisplayMemberBinding="{Binding Path=Category}" Header="Category" Width="100" />
                                                </GridView>
                                            </ListView.View>
                                        </ListView>
                                    </StackPanel>
                                </Border>
                            </StackPanel>
                        </Border>
                        <ControlTemplate.Triggers>
                            <Trigger Property="IsSelected" Value="True">
                                <Setter TargetName="details" Property="Visibility" Value="Visible" />
                                <Setter TargetName="presenter" Property="Background" Value="Navy"/>
                                <Setter TargetName="presenter" Property="TextElement.Foreground" Value="White" />
                            </Trigger>
                        </ControlTemplate.Triggers>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </ListView.Resources>
</ListView>
4

3 に答える 3

1

あなたの質問を正しく理解できたら、元のリストの SelectedItem にバインドする必要があります。

<ListView ItemsSource="{Binding ElementName=lstHistory, Path=SelectedItem}">

そして、必要に応じて datatemplate/view を設定します。バインディングに ElementName を使用したくない場合は、RelativeSource を使用することもできますが、ElementName の方が読みやすく、理解しやすいと思います。

于 2008-12-09T19:27:44.480 に答える
0

問題の行を次のように変更する必要があります。

<ListView ItemsSource="{Binding FK_History_HistoryItems}">

その変更により、コントロールは美しく機能します。私は無駄に似た何かに取り組んできました。私はこれに関するあなたの仕事が本当に好きです。

于 2009-01-30T23:33:54.190 に答える
0

トリガーを機能させるには、ControlTemplate の TargetType を設定する必要があります。

<ControlTemplate TargetType="{x:Type ListViewItem}">

TargetType が (Selectable 型として) 指定されていないと、XAML レンダリングが混乱します...

于 2015-10-07T14:50:21.863 に答える