0

我有一个名为 Books 的课程。代码在这里:

class Books
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string description { get; set; }    
    }

我的表单后面的代码如下所示:(感谢 Omribitan)

 public partial class MainWindow : Window
    {

        private ObservableCollection<Books> Books { get; set; }
        public MainWindow()
        {
            InitializeComponent();

        }

        private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            var db = new DataClasses1DataContext();
            var query = from p in db.books
                        select new Books
                        {
                            Id = p.id,
                            Name = p.name,
                            description = p.description
                        };

            Books = new ObservableCollection<Books>(query);
            listview1.ItemsSource = Books;

            }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            var book = listview1.SelectedItem as Books;
            MessageBox.Show(book.Id.ToString());
        }

XAML 如下所示:

xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:test" xmlns:System="clr-namespace:System;assembly=mscorlib" x:Class="test.MainWindow"
        Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded">
    <Grid>
        <ListView x:Name="listview1" HorizontalAlignment="Left" Height="100" Margin="126,91,0,0" VerticalAlignment="Top" Width="286">
            <ListView.View>
                <GridView>
                    <GridViewColumn Header="BookName"
                      Width="Auto"
               DisplayMemberBinding="{Binding Name}" />
                    <GridViewColumn Header="Publisher"
                      Width="Auto"
               DisplayMemberBinding="{Binding Description}" />
                </GridView>
            </ListView.View>
        </ListView>

使用此代码,我想将我的数据绑定到列表视图。问题是当我运行这段代码时,我的列表视图的第二列是空的。有人可以帮我吗?

4

2 回答 2

0

首先像@HighCore 建议的那样,创建一个适当的数据类型而不是匿名类型。

public class Book
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }
}

创建一个集合,例如ObservableCollection

public ObservableCollection<Book> Books { get; set; }

将您的项目添加到集合中

var db=new mydataDataContext();
var query=from p in db.Book
select new Book{
            Id = p.Id
            Name = P.Name
            Description = P.Description
           };
Books = new ObservableCollection<Book>(query);

接下来,将ItemsSourceListView的集合设置为

myListView.ItemsSource = Books; 

ListView应该看起来像这样:

<ListView x:Name="myListView">
  <ListView.View>
    <GridView>
      <GridViewColumn Header="BookName"
                      Width="Auto"
               DisplayMemberBinding="{Binding Name}" />
      <GridViewColumn Header="Publisher"
                      Width="Auto"
               DisplayMemberBinding="{Binding Description}" />
    </GridView>
  </ListView.View>
</ListView>

现在,您可以像这样访问它,而不是将 Id 隐藏在第一列中

var book = myListView.SelectedItem as Book;
book.Id ....

希望这可以帮助

于 2013-10-22T16:21:55.560 回答
0

感谢亲爱的 Omribitan 代码,问题出在 xaml 中的发布者列(第二列)中。当我将 DisplayMemberBinding="{Binding Description}" 更改为 DisplayMemberBinding="{Binding description}" 它工作正常。

于 2013-10-24T11:26:35.977 回答