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. oracle获取字符串长度函数length()和lengthb()

    oracle获取字符串长度函数length()和lengthb()   lengthb(string)计算string所占的字节长度:返回字符串的长度,单位是字节 length(string)计算st ...

  2. Linux的基本优化

    归结成口诀: 一清.一精.一增.两优.四设.七其他 一清: 定时清理日志/var/spool/clientsqueue 一精: 精简开机启动服务 一增: 增大文件描述符 两优: linux内核参数的优 ...

  3. ubuntu下打开eclipse·发现没有顶尖菜单项

    在安装eclipse时,打开集成开发环境后没有菜单项. 网上些人说要写个shell脚步,感觉有点麻烦,其实就是少了一个环境变量 BUNTU_MENUPROXY. 在/etc/profile 里面新建这 ...

  4. xcode 程序配置 python 解释器嵌入

    1.点击项目->Buid Phases->加号点击 添加RunScript,Shell中写为python路径.一般是/usr/bin/python 2.同样是Build Phases中,L ...

  5. button和submit区别

    type=button      就单纯是按钮功能 type=submit      是发送表单 但是对于从事WEB UI的人应该要注意到,使用submit来提高页面易用性: 使用submit后,页面 ...

  6. oracle经典建表语句--scott建表

    create table EMP ( EMPNO ) PRIMARY KEY, ENAME ), JOB ), MGR ), HIREDATE DATE, SAL ,), COMM ,), DEPNO ...

  7. 珠海鼎芯(D-Chip)IMX6读取CPU的UID的方法【转】

    本文转载自:http://blog.csdn.net/williamdedong/article/details/52712084 在使用IMX6板子的时候,有时会想着是否可以把板子搞一个唯一标识呢, ...

  8. Linux 杀死所有进程

    方法一: sudo killall -9 netease-cloud-music 这种方法,必须要写全称. sudo netease-cloud-music QStandardPaths: XDG_R ...

  9. ES6 基础知识-----简记 let const

    ES5中只有函数作用域和全局作用域,声明变量使用var,在es6中添加声明变量 let const let 声明块级作用域变量, let 不存在变量提升 var命令会发生”变量提升“现象,即变量可以在 ...

  10. codeforces round#432 div2

    C:这道题没做出来...写了个类似极角排序的东西被卡掉了...事实上暴力就行了,因为如果在二维平面内那么最多只能有4个点,因为每个象限只能有一个点,然后这里拓展一下就是最多只能有2*k个点,k是维数, ...