【问题标题】:Binding ObservableCollection inside an ObservableCollection在 ObservableCollection 中绑定 ObservableCollection
【发布时间】:2016-08-17 10:16:21
【问题描述】:

我已经对这个问题进行了多次搜索,但我仍然无法弄清楚我的项目出了什么问题。流程是这样的:
我想绑定一个视图模型。此视图模型包含observablecollection,其中包含observablecollection。 现在我可以在开发过程中毫无问题地绑定到observablecollections,但是当我部署它时,另一个observablecollection 中的数据没有显示出来。

下面是我的代码:

Project/Model/SubProduct.cs

class SubProducts
{
    private string subName;

    public string SubName
    {
        get
        {
            return subName;
        }

        set
        {
            subName = value;
        }
    }
}

项目/模型/Product.cs

public class Product
{
    private string name;

    public string Name
    {
        get
        {
            return name;
        }

        set
        {
            name = value;
        }
    }
    private ObservableCollection<SubProducts> subProductsSaProducts;
    internal ObservableCollection<SubProducts> SubProductsSaProducts
    {
        get
        {
            return subProductsSaProducts;
        }

        set
        {
            subProductsSaProducts = value;
        }
    }
}

项目/模型/Category.cs

class Category
{
    private string title;
    public string Title
    {
        get
        {
            return title;
        }

        set
        {
            title = value;
        }
    }
    private ObservableCollection<Product> subProducts;
    public ObservableCollection<Product> SubProducts
    {
        get
        {
            return subProducts;
        }

        set
        {
            subProducts = value;
        }
    }
}

这是实现模型的视图模型: 项目/ViewModel/CategoryViewModel.cs

class CategoryViewModel : ObservableCollection<Category>
{
    public CategoryViewModel()
    {
        ObservableCollection<Product> pCOl1 = new ObservableCollection<Product>();

        ObservableCollection<SubProducts> pCol1Sub = new ObservableCollection<SubProducts>();
        SubProducts subP1 = new SubProducts();
        subP1.SubName = "Lansang";
        SubProducts subP2 = new SubProducts();
        subP2.SubName = "Lata";
        pCol1Sub.Add(subP1);
        pCol1Sub.Add(subP2);

        Product p1 = new Product();
        p1.Name = "Pothaw";
        p1.SubProductsSaProducts = pCol1Sub;
        pCOl1.Add(p1);

        ObservableCollection<Product> pCOl2 = new ObservableCollection<Product>();
        Product p2 = new Product();
        p2.Name = "Taklob sa COke";
        pCOl2.Add(p2);

        Add(new Category()
        {
            Title = "Didang",
            SubProducts = pCOl1
        });
        Add(new Category()
        {
            Title = "Plastic",
            SubProducts = pCOl2
        });
    }
}

我在页面中使用 xaml 中的视图模型:

<Page.DataContext>
    <vm:CategoryViewModel/>
</Page.DataContext>
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
    <FlipView x:Name="flipView" HorizontalAlignment="Left" VerticalAlignment="Top" Width="360" ItemsSource="{Binding}" Background="#19B0F100">
        <FlipView.ItemTemplate>
            <DataTemplate>
                <StackPanel>
                    <TextBlock Foreground="Black" FontSize="30" Text="{Binding Title}"/>
                    <ListView ItemsSource="{Binding SubProducts}" Background="#FF0C0909" Height="600">
                        <ListView.ItemTemplate>
                            <DataTemplate>
                                <StackPanel Orientation="Vertical">
                                    <TextBlock Foreground="Red" FontSize="30" Text="{Binding Name}"/>
                                    <ListView  ItemsSource="{Binding SubProductsSaProducts}" Margin="30,0,0,0" Background="#FF933131" Height="197" Width="300">
                                        <ListView.ItemTemplate>
                                            <DataTemplate>
                                                <TextBlock Foreground="Yellow" FontSize="20" Text="{Binding SubName}"/>
                                            </DataTemplate>
                                        </ListView.ItemTemplate>
                                    </ListView>
                                </StackPanel>
                            </DataTemplate>
                        </ListView.ItemTemplate>
                    </ListView>
                </StackPanel>
            </DataTemplate>
        </FlipView.ItemTemplate>
    </FlipView>
</Grid>

现在预期数据显示在开发模式中。换句话说,数据仅在不运行应用程序时显示。

我的问题是:

  1. 我的绑定有什么问题?
  2. 正确的做法是什么?
  3. 为什么我运行应用程序时没有显示数据?

我是 C# WinRT 开发的新手,因此我们将不胜感激。 下面是截图:

【问题讨论】:

  • 先生,我该怎么做?
  • ObservableCollection&lt;ObservableCollection&lt;Item&gt;&gt; 可以,class MyCollection: ObservableCollection&lt;Item&gt; 不行。
  • 我真的很抱歉先生..请提供示例...我真的是 C# 新手。我仍然不能让事情变得更快:(

标签: c# data-binding observablecollection


【解决方案1】:

您应该从 Category 类而不是 ObservableCollection 继承。 另外我认为 Category 类中没有 SubProductsSaProducts 属性,因为您将页面绑定到继承自 ObservableCollection 的 CategoryViewMode

【讨论】:

  • 你的意思是,公共类 CategoryViewModel : Category 而不是公共类 CategoryViewModel : ObservableCollection ?但我需要收集物品?我该怎么做呢?
猜你喜欢
  • 2011-04-10
  • 1970-01-01
  • 2014-01-14
  • 1970-01-01
  • 2019-08-08
  • 2012-10-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多