通过LINQ我们可以方便的操作集合对象、DataTable对象而不必动辄就把好几层foreach循环嵌套在一起只是为了完成一个很简单的任务。
集合类
class Student { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } }
界面代码,设定一个数据表格安装数据
<StackPanel Background="LightBlue"> <ListView x:Name="listViewStudents" Height="143" Margin="5"> <ListView.View> <GridView> <GridViewColumn Header="Id" Width="60" DisplayMemberBinding="{Binding Id}"/> <GridViewColumn Header="Name" Width="100" DisplayMemberBinding="{Binding Name}"/> <GridViewColumn Header="Age" Width="80" DisplayMemberBinding="{Binding Age}"/> </GridView> </ListView.View> </ListView> <Button Content=" Load" Height="25" Margin="5,0" Click="Button_Click"/> </StackPanel>
后台代码
private void Button_Click(object sender, RoutedEventArgs e) { List<Student> stuList = new List<Student>(); { stuList.Add(new Student() { Id = 1, Name = "Tim", Age = 29 }); stuList.Add(new Student() { Id = 1, Name = "Tom", Age = 28 }); stuList.Add(new Student() { Id = 2, Name = "Kyle", Age = 27 }); stuList.Add(new Student() { Id = 3, Name = "Tony", Age = 26 }); stuList.Add(new Student() { Id = 4, Name = "Vina", Age = 25 }); stuList.Add(new Student() { Id = 5, Name = "Mike", Age = 24 }); }; this.listViewStudents.ItemsSource = from stu in stuList where stu.Name.StartsWith("T") select stu; }最后,调用的结果如下