WPF学习03:Element Binding我们可以实现控件属性与控件属性的绑定。

WPF学习07:MVVM 预备知识之数据绑定 我们可以实现控件属性与自定义对象属性的绑定。

而以上两个功能在实际应用中还是不够的,我们经常需要将列表数据与控件属性进行绑定。

例子

ListBox切换人物,下面两个文本框跟随切换,很常用的功能。

XAML代码:

<Window x:Class="DataTemplate.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">
<StackPanel>
<ListBox IsSynchronizedWithCurrentItem="True" ItemsSource="{Binding}" DisplayMemberPath="Name"/>
<StackPanel HorizontalAlignment="Center" Orientation="Horizontal">
<TextBlock Text="性别:"></TextBlock>
<TextBlock Text="{Binding Gender}" Margin="0 0 100 0"></TextBlock>
<TextBlock Text="年龄:"></TextBlock>
<TextBlock Text="{Binding Age}" Margin="0 0 100 0"></TextBlock>
</StackPanel>
</StackPanel>
</Window>

后台代码:

public class Person : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
private void Notify(String propertyName)
{
if (PropertyChanged != null)
PropertyChanged.Invoke(this, new PropertyChangedEventArgs(propertyName));
} private Int32 age;
public Int32 Age
{
get { return age; }
set
{
age = value;
Notify("Age");
}
} private String gender;
public String Gender
{
get { return gender; }
set
{
gender = value;
Notify("Gender");
}
} private String name;
public String Name
{
get { return name; }
set
{
name = value;
Notify("Name");
}
}
} class People : List<Person>
{
public People()
{
this.Add(new Person() { Name = "John", Age = 30, Gender = "Male" });
this.Add(new Person() { Name = "Jake", Age = 26, Gender = "Male" });
this.Add(new Person() { Name = "Kate", Age = 25, Gender = "Female" });
}
} public MainWindow()
{
InitializeComponent();
DataContext = new People();
}

Collection View

将例子做一些改动:

仅仅是改动了XAML。删掉了原有的ListBox,增加了一个TextBlock与两个Button

<StackPanel HorizontalAlignment="Center" Orientation="Horizontal">
<TextBlock Text="姓名:"></TextBlock>
<TextBlock Text="{Binding Name}" Margin="0 0 100 0"></TextBlock>
<TextBlock Text="性别:"></TextBlock>
<TextBlock Text="{Binding Gender}" Margin="0 0 100 0"></TextBlock>
<TextBlock Text="年龄:"></TextBlock>
<TextBlock Text="{Binding Age}"></TextBlock>
</StackPanel>

数据绑定设置的路径为Name Gender Age 而当前的数据上下文却是个列表。在这种情况出现时,WPF会尝试当前数据列表的Current Item 视作绑定源。从而有了图片上的效果。

通过CollectionViewSource提供的GetDefaultView方法我们可以获得列表视图,列表视图可以使我们对列表进行包括但不限于改变Current Item的操作。

我们为两个按钮添加Handler,即可实现按钮切换人物的功能:

private void BtnToRight_Click(object sender, RoutedEventArgs e)
{
var view = CollectionViewSource.GetDefaultView(DataContext);
view.MoveCurrentToNext();
//越界,返回
if (view.IsCurrentAfterLast)
view.MoveCurrentToPrevious();
} private void BtnToLeft_Click(object sender, RoutedEventArgs e)
{
var view = CollectionViewSource.GetDefaultView(DataContext);
view.MoveCurrentToPrevious();
//越界,返回
if (view.IsCurrentBeforeFirst)
view.MoveCurrentToNext();
}

获取了列表视图后,我们还可以对数据列表进行过滤,排序等操作。在此略去例子。


IsSynchronizedWithCurrentItem

再回到文章最开始的例子中。之所以可以通过点击ListVox中的元素就能实现两个文字框内容的切换有两个原因:

1.他们的数据绑定,源相同(当前数据上下文)。

2.配置IsSynchronizedWithCurrentItem为 ture。

这样,ListControl可在SelectedItem切换时,自动切换当前绑定列表的CurrentItem。


DataTemplate简介

因为数据模板的东西太多,无法一次说完,在此先给出一个数据模板的例子。

通过数据模板,我们可以自由的定义数据的显示内容。

继续对本文开头的例子进行修改。首先要去掉该元素的DisplayMemberPath属性,该属性指定了绑定对象的哪一个属性做为Item的显示绑定对象。与数据模板功能冲突,故而去之。

改动后的效果:

改动后的XAML代码:

<Window x:Class="DataTemplate.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">
<ListBox IsSynchronizedWithCurrentItem="True" ItemsSource="{Binding}">
<ListBox.ItemTemplate>
<DataTemplate>
<StackPanel HorizontalAlignment="Center" Orientation="Horizontal">
<TextBlock Text="姓名:"></TextBlock>
<TextBlock Text="{Binding Name}" Margin="0 0 100 0"></TextBlock>
<TextBlock Text="性别:"></TextBlock>
<TextBlock Text="{Binding Gender}" Margin="0 0 100 0"></TextBlock>
<TextBlock Text="年龄:"></TextBlock>
<TextBlock Text="{Binding Age}"></TextBlock>
</StackPanel>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</Window>

WPF学习09:数据绑定之 Binding to List Data的更多相关文章

  1. WPF学习之数据绑定

    WPF中的数据绑定提供了很强大的功能.与普通的WinForm程序相比,其绑定功能为我们提供了很多便利,例如Binding对象的自动通知/刷新,Converter,Validation Rules,Tw ...

  2. WPF学习03:Element Binding

    元素绑定是数据绑定的一个子集,关于数据绑定是什么,园子里有很多文章都说得非常好,在此不予详细说明. WPF实现了完善的数据绑定机制,使得元素绑定有简易的实现步骤. 本文的元素指的是WPF中的可视控件. ...

  3. [WPF系列]-DataBinding(数据绑定) 自定义Binding

    自定义Binding A base class for custom WPF binding markup extensions BindingDecoratorBase Code: public c ...

  4. WPF学习笔记 - 数据绑定(在代码中)

    在程序代码里,有两种设置绑定的方法,一种是调用FrameworkElement或FrameContentElement对象的SetBinding实例方法. 例如: Public MainWindow( ...

  5. WPF学习07:MVVM 预备知识之数据绑定

    MVVM是一种模式,而WPF的数据绑定机制是一种WPF内建的功能集,两者是不相关的. 但是,借助WPF各种内建功能集,如数据绑定.命令.数据模板,我们可以高效的在WPF上实现MVVM.因此,我们需要对 ...

  6. WPF学习10:基于MVVM Light 制作图形编辑工具(1)

    图形编辑器的功能如下图所示: 除了MVVM Light 框架是一个新东西之外,本文所涉及内容之前的WPF学习0-9基本都有相关介绍. 本节中,将搭建编辑器的界面,搭建MVVM Light 框架的使用环 ...

  7. WPF中的数据绑定

    WPF中的数据绑定 基础概念 System.Windows.Data.Binding,他会把两个对象(UI对象与UI对象之间,UI对象与.NET数据对象之间)按照指定的方式粘合在一起,并在他们之间建立 ...

  8. WPF学习(8)数据绑定

    说到数据绑定,其实这并不是一个新的玩意儿.了解asp.net的朋友都知道,在asp.net中已经用到了这个概念,例如Repeater等的数据绑定.那么,在WPF中的数据绑定相比较传统的asp.net中 ...

  9. WPF学习(8)数据绑定 https://www.cnblogs.com/jellochen/p/3541197.html

    说到数据绑定,其实这并不是一个新的玩意儿.了解asp.net的朋友都知道,在asp.net中已经用到了这个概念,例如Repeater等的数据绑定.那么,在WPF中的数据绑定相比较传统的asp.net中 ...

随机推荐

  1. Xsolla和Hi-Rez工作室联手推行SMITE

    视频游戏店面管理和计费解决方式的领导者,Xsolla.将重拳出击将与Hi-Rez游戏工作室合作.该工作室是一家美国的独立游戏开发商,主要开发MOBA游戏-SMITE. 支持全球600多种支付方式 Xs ...

  2. 5 微信票据 access_token--开发微信的第二道坎儿

    一 access_token基本概念 定义:access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token.开发者需要进行妥善保存. 时效性:access_ ...

  3. MySql InnoDb还原工具

    通过任意文件下载找到了mysql的备份,表类型是独享式innodb,由一个frm文件和一个ibd文件组成. 本以为直接复制到本地的mysql数据目录中即可恢复数据,但在查询时却发现并不如所愿: mys ...

  4. 密码过期导致Oracle process耗尽问题

    oracle忽然连不上! 大致是报这样的错: ORA-12516: TNS: 监听程序找不到符合协议堆栈要求的可用处理程序 ORA-12520: TNS: 监听程序无法为请求的服务器类型找到可用的处理 ...

  5. sql 统计 url字符串处理

    SELECT SUBSTRING_INDEX(url,'/',1) AS wed_domain,COUNT(1),SUM(no_open_times),SUM(no_ad_times),SUM(ok_ ...

  6. p_CreateAuditEntry

    如果你能搜到我这篇博客,相信你导遇到的了和我一样在导入CRM组织时遇到了类似的错误.这个错误我查资料可以通过CRM升级来解决参考下面连接: https://support.microsoft.com/ ...

  7. Enum的基本使用

    package enum_test; public enum Shrubbery { GROUND, CRAWLING, HANGING } package enum_test; public cla ...

  8. RDD的基本命令

    1 创建RDD intRDD=sc.parallelize([3,1,2,5,6]) intRDD.collect()[4, 2, 3, 6, 7] 2 单RDD转换 (1) MAP def addo ...

  9. Masonry remake更新约束

    前言 说到iOS自动布局,有很多的解决办法.有的人使用xib/storyboard自动布局,也有人使用frame来适配.对于前者,笔者并不喜欢,也不支持.对于后者,更是麻烦,到处计算高度.宽度等,千万 ...

  10. Java 并发 —— 读写锁(ReadWriteLock)

    读写锁(ReadWriteLock),顾名思义,就是在读写某文件时,对该文件上锁. 1. ReentrantReadWriteLock 三部曲: 加锁: 读写操作: 解锁:(为保证解锁操作一定执行,通 ...