带有绑定数据的列表框内的列表框

时间:2013-08-14 06:06:58

标签: c# xaml data-binding windows-8 listbox

是否可以将Listbox放在另一个列表框中?两个列表框都绑定相同的数据只有第二个列表框添加了一些东西。我没有得到任何错误只有第二个列表框中的数据(内部第一个)没有显示或绑定不工作我不知道。第一个列表框的数据是绑定好的。我的样本:

<Grid Grid.Row="2">
        <ListBox x:Name="lbTransitNow" FontSize="13" ItemsSource="{Binding  MyDataForTransit}">
            <ListBox.ItemContainerStyle>
                <Style TargetType="ListBoxItem">
                    <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
                </Style>
            </ListBox.ItemContainerStyle>
            <ListBox.ItemTemplate>
                <DataTemplate >
                    <StackPanel>
                        <Grid x:Name="gridTodayBtn">
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />
                                <ColumnDefinition Width="*" />

                            </Grid.ColumnDefinitions>
                            <TextBlock x:Name="tbTransitStart" Foreground="Black" Grid.Column="0"
                                             Text="{Binding Lines_departure_time}" HorizontalAlignment="Left"/>
                            <TextBlock x:Name="tbTransitEnd" Foreground="Black" Text="{Binding Lines_arrival_time}"
                                               Grid.Column="1"/>
                            <TextBlock x:Name="tbTransitTravelTime" Foreground="Black" Text="{Binding Lines_travelTime}"
                                               Grid.Column="2"/>
                            <TextBlock x:Name="tbPrice" Foreground="Black" Text="{Binding Lines_price}"
                                               Grid.Column="3"/>
                            <TextBlock x:Name="tbTransitKm" Foreground="Black" Text="{Binding Lines_km}"
                                               Grid.Column="4"/>
                            <TextBlock x:Name="tbTransitNumber" Foreground="Black" Text="{Binding Lines_name}"
                                               Grid.Column="5"/>
                            <Image x:Name="imgMoreInfo" Source="layoutGraphics/b5.png" Grid.Column="6" Width="40" Height="40" Tapped="imgMoreInfo_Tapped"  Tag="{Binding}"></Image>

                            <ListBox x:Name="lbTransitNowSub" FontSize="13" ItemsSource="{Binding  MyDataForTransit}">
                                <ListBox.ItemContainerStyle>
                                    <Style TargetType="ListBoxItem">
                                        <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
                                    </Style>
                                </ListBox.ItemContainerStyle>
                                <ListBox.ItemTemplate>
                                    <DataTemplate >
                                        <Grid x:Name="gridTodayBtn">
                                            <Grid.ColumnDefinitions>
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />
                                                <ColumnDefinition Width="*" />

                                            </Grid.ColumnDefinitions>
                                            <TextBlock x:Name="tbTransitStart" Foreground="Black" Grid.Column="0"
                                             Text="{Binding Lines_departure_time}" HorizontalAlignment="Left"/>
                                            <TextBlock x:Name="tbTransitEnd" Foreground="Black" Text="{Binding Lines_arrival_time}"
                                               Grid.Column="1"/>
                                            <TextBlock x:Name="tbTransitTravelTime" Foreground="Black" Text="{Binding Lines_travelTime}"
                                               Grid.Column="2"/>
                                            <TextBlock x:Name="tbPrice" Foreground="Black" Text="{Binding Lines_price}"
                                               Grid.Column="3"/>
                                            <TextBlock x:Name="tbTransitKm" Foreground="Black" Text="{Binding Lines_km}"
                                               Grid.Column="4"/>
                                            <TextBlock x:Name="tbTransitNumber" Foreground="Black" Text="{Binding Lines_name}"
                                               Grid.Column="5"/>
                                            <Image x:Name="imgMoreInfo" Source="layoutGraphics/b5.png" Grid.Column="6" Width="40" Height="40" Tapped="imgMoreInfo_Tapped"  Tag="{Binding}"></Image>
                                        </Grid>
                                    </DataTemplate>
                                </ListBox.ItemTemplate>
                            </ListBox>
                        </Grid>
                    </StackPanel>
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>

    </Grid>

  public ObservableCollection<BindingData> _myDataForTransit = new ObservableCollection<BindingData>();
    public ObservableCollection<BindingData> MyDataForTransit
    {
        get { return _myDataForTransit; }
        set { _myDataForTransit = value; }
    }

    public event PropertyChangedEventHandler PropertyChanged;

    public void OnPropertyChanged(string propertyName)
    {
        if (PropertyChanged != null)
        {
            PropertyChanged(null, new PropertyChangedEventArgs(propertyName));
        }
    }

 _myDataForTransit.Add(new BindingData
            {
                myData...
            });
            }
            OnPropertyChanged("MyDataForTransit");

1 个答案:

答案 0 :(得分:0)

首先,您的方法不能代替,您可以使用collectionViewsource来实现分组数据。

不绑定的原因是因为您的第二个Listbox位于First Listbox的Datatemplate中,因此其DataContext被设置为 MyDataForTransit 的Parent的DataContext,并且此集合不包含集合 MyDataForTransit ,你的第二个listBox被绑定,所以你的第二个列表框没有显示任何内容。

为了检查这个,在BindingData Class中创建一个集合,并将第二个ListBox ItemsSource绑定到此Collection,您将发现它正在工作。 实际上在wpf中有一个名为relativeSource的属性,它可以很容易地设置为你的类/ page / usercontrol但是在windows 8中我无法做到这一点。 希望它会以某种方式帮助你..