2

我知道我发布了这个问题,但是接受了我最后一个问题的答案并阅读了这篇文章后,我意识到这不是我想要的答案。我再次发布了一些示例代码。

我想用集合中的数据填充网格(不是 DataGrid)。这是我所拥有的,但它不起作用。如果我删除集合并将 DataContext 设置为单个对象,它可以工作,但不能作为集合。

XAML

Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
        <StackPanel>
            <TextBlock Text="{Binding Path=StudentName}" />
        </StackPanel>
</Grid>

MainPage.xaml.cs

public MainPage()
    {
        InitializeComponent();

        ObservableCollection<Student> ob = new ObservableCollection<Student>();

        ob.Add(new Student()
        {
            StudentName = "James Jeffery"
        });

        ob.Add(new Student()
        {
            StudentName = "Sian Ellis"
        });



        this.DataContext = ob;

        // Sample code to localize the ApplicationBar
        //BuildLocalizedApplicationBar();
    }

这一直困扰着我几个小时。我似乎无法用集合填充网格。Google 上的每个示例都显示 ListViews 等。我想填充一个网格,并且只填充一个网格。

关于如何实现这一目标的任何建议?

4

2 回答 2

1

如另一个答案中所述,您需要一个ItemsControl

<Window x:Class="MiscSamples.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">
    <ItemsControl ItemsSource="{Binding}">
        <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
                <UniformGrid IsItemsHost="True" Rows="3" Columns="3"/>
            </ItemsPanelTemplate>
        </ItemsControl.ItemsPanel>
        <ItemsControl.ItemTemplate>
            <DataTemplate>
                <StackPanel>
                    <TextBox Text="{Binding Name}" Margin="2"/>
                </StackPanel>
            </DataTemplate>
        </ItemsControl.ItemTemplate>
    </ItemsControl>
</Window>

代码背后:

 public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            DataContext = new List<Student>
                {
                    new Student() {Name = "James Jeffery"},
                    new Student() {Name = "Sian Ellis"},
                    new Student() {Name = "James Jeffery 2"},
                    new Student() {Name = "Sian Ellis 2"},
                    new Student() {Name = "James Jeffery 3"},
                    new Student() {Name = "Sian Ellis 3"},
                };
        }
    }

输出:

在此处输入图像描述

于 2013-03-19T00:41:59.190 回答
0

你不能。网格无法做到这一点。您需要使用 ItemsControl 或 ItemsControl 的后代。

试试这个教程:http ://www.galasoft.ch/mydotnet/articles/article-2007041201.aspx

于 2013-03-19T00:21:28.937 回答