ItemsControl使用WrapPanel,不显示任何内容

时间:2017-04-30 01:20:47

标签: c# wpf itemscontrol

目标:我正在尝试创建一个包含绑定到可观察集合的子项的包装面板。

当前的预期行为:我希望看到3个嵌套的包裹面板,它们有一个椭圆,一个文本块,一个标签和一个复选框。

问题:我的包装面板和内容在运行时不显示。 (注意:"测试"和"测试2" itemscontrol外的标签会按预期显示。)

我已阅读this,但它似乎无法解决我的问题。

背后的代码

order_b

XAML

using MVVM_SandBox.Models;
using MVVM_SandBox.ViewModels;

namespace MVVM_SandBox
{
    public partial class MainWindow
    {     
        public MainViewModel VMMain = new MainViewModel();


        public MainWindow()
        {
            VMMain.SomeItemModelBlahs = new System.Collections.ObjectModel.ObservableCollection<ItemModelBlah>() { new ItemModelBlah() { Label = "blah0" }, new ItemModelBlah() { Label = "blah1", CoolStuff = true }, new ItemModelBlah() { Label = "blah2" } };
            InitializeComponent();


        }
    }
}

查看模型

<Window x:Name="winMain" x:Class="MVVM_SandBox.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

                     xmlns:viewmodels="clr-namespace:MVVM_SandBox.ViewModels"
                     Title="MVVM SandBox" Height="600" Width="800" AllowDrop="True">
    <Window.DataContext>
        <viewmodels:MainViewModel></viewmodels:MainViewModel>
    </Window.DataContext>
    <StackPanel>
        <Label Width="Auto" Height="Auto">Test</Label>
        <ItemsControl ItemsSource="{Binding SomeItemModelBlahs}" Margin="10,10,10,10">
                <ItemsControl.ItemsPanel>
                    <ItemsPanelTemplate>
                        <WrapPanel x:Name="WrapPanelOfModelItems" Margin="10,10,10,10" Width="400" Height="200" IsItemsHost="True" MinWidth="200" MinHeight="200">
                        </WrapPanel>
                    </ItemsPanelTemplate>
                </ItemsControl.ItemsPanel>
            <ItemsControl.ItemTemplate>
                <DataTemplate>
                    <StackPanel Width="100" Height="100" Margin="10">
                        <Ellipse Width="10" Height="10" Fill="Aqua"></Ellipse>
                        <TextBlock Margin="10" Text="{Binding Label}"></TextBlock>
                        <Label>kjasdkjalsdjklsad</Label>
                        <CheckBox IsChecked="{Binding CoolStuff}">
                            <Label>Hello</Label> 
                        </CheckBox>
                    </StackPanel>
                </DataTemplate>
            </ItemsControl.ItemTemplate>
            </ItemsControl>
        <Label Height="Auto" Width="Auto">Test 2</Label>
    </StackPanel>

</Window>

模型

using MVVM_SandBox.Models;
using System.Collections.ObjectModel;


namespace MVVM_SandBox.ViewModels
{
    //[ImplementPropertyChanged]
    public class MainViewModel
    {
        public ObservableCollection<ItemModelBlah> SomeItemModelBlahs { get; set; }

        public MainViewModel()
        {

        }
    }
}

1 个答案:

答案 0 :(得分:2)

代码创建了MainViewModel的两个实例:一次在后面的代码中,一次又在XAML中。实例背后的代码具有非空ObservableCollection,而XAML中的实例设置为DataContext

我建议从XAML中删除viewmodels:MainViewModel,并仅在代码中创建它:

public partial class MainWindow
{     
    public MainViewModel VMMain = new MainViewModel();

    public MainWindow()
    {
        DataContext = VWMain;
        InitializeComponent();
    }
}

此外,从视图模型本身设置ObservableCollection是更好的设计:

class MainViewModel
{
    public ObservableCollection<ItemModelBlah> SomeItemModelBlahs { get; private set; }

    public MainViewModel()
    {
        SomeItemModelBlahs = new ObservableCollection<ItemModelBlah>()
        {
            new ItemModelBlah() { Label = "blah0" },
            new ItemModelBlah() { Label = "blah1", CoolStuff = true },
            new ItemModelBlah() { Label = "blah2" }
        };
    }
}