使用MVVM以编程方式使用可观察的用户控件集合填充堆栈面板

时间:2011-07-13 15:29:30

标签: mvvm controls observablecollection stackpanel

我有一个类型frameworkelement的observablecollection,我想在stackpanel或类似的东西中显示。 observablecollection中的每个项都是我创建的用户控件。我是WPF的新手,我不知道如何做到这一点。非常感谢一个例子

2 个答案:

答案 0 :(得分:4)

我在这里借用了rhe1980的答案,但问题是代码隐藏中的代码实际上是在一个视图模型中。

查看:

<Window x:Class="Sandbox.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525"
Name="mainWindow">
<Grid>
<StackPanel>
    <ItemsControl ItemsSource="{Binding Path=MyCollection}"/>                           
</StackPanel>         
</Grid>

代码隐藏:

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
        this.DataContext = new MyViewModel();
    }
}

视图模型:

    public class MyViewModel: INotifyPropertyChanged
{

    public event PropertyChangedEventHandler PropertyChanged;
    protected void OnPropertyChanged(string propertyName)
    {
        if (!string.IsNullOrEmpty(propertyName))
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }
        this.OnObjectChanged();
    } 

   private ObservableCollection<FrameworkElement> _myCollection;
   public ObservableCollection<FrameworkElement> MyCollection
    {
        get
        {
            return _myCollection;
        }
        set
        {
            _myCollection = value;
            OnPropertyChanged("MyCollection");
        }
    }     
}

答案 1 :(得分:2)

使用ItemsControl绑定StackPanel中的ObservableCollection:

查看(XAML):

<Window x:Class="Sandbox.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="MainWindow" Height="350" Width="525"
    Name="mainWindow">
<Grid>
    <StackPanel>
        <ItemsControl ItemsSource="{Binding ElementName=mainWindow,Path=ObservableCollection}"/>                           
    </StackPanel>         
</Grid>

代码隐藏(xaml.cs):

public partial class MainWindow : Window
{
    public ObservableCollection<FrameworkElement> ObservableCollection { get; set; }

    public MainWindow()
    {
        InitializeObservableCollection();
        InitializeComponent();
    }

    private void InitializeObservableCollection()
    {
        ObservableCollection = new ObservableCollection<FrameworkElement>();
        for (var ii = 0; ii < 10; ii++)
        {
            ObservableCollection.Add(new Button {Content = ii.ToString()});
        }
    }
}