.NET各大平台数据列表控件绑定原理及比较(WebForm、Winform、WPF)

简介:

说说WebForm:

数据列表控件:

WebForm 下的列表绑定控件基本就是GridView、DataList、Repeater;当然还有其它DropDownList、ListBox等。


它们的共同的设置数据源方法:

XXX.DataSource=数据源。


那么这个数据源的格式,究竟有啥要求?最简单的方式是随便给弄个,然后等它抛异常:

11161746-a366591306324fb48f1aba155cfe789


从上面的错误可以看的出来,基本上支持三种数据源绑定方式:IListSource,IEnumerable,IDataSource。


说说Winform

数据列表控件:

WinForm 下的列表绑定控件基本就是DataGridView、ListView、ComboBox等。


它们的共同的设置数据源方法:

XXX.DataSource=数据源。


用同样的方式,发现它是死活不抛异常的,通过对DataGridView的DataSource查看代码:

11162833-689e6b80bce849c5aa400f5adf0ab3d

一个不够再看一下ComboBox的DataSource:

11162945-95691f3307c04eea9ec30df235e0d90

从以上的提示可以得到信息,数据源支持:IListSource接口。


看看WPF

数据列表控件:

WPF 下的列表绑定控件基本就是DataGrid、ListBox、ComboBox等。


它们的共同的设置数据源方法:

XXX. ItemsSource =数据源。


对于WPF,它的ItemsSource不再是Object类型,而是IEnumerable:

11163603-c949bf7707734658b1f226a9320b4f0

从以上的提示可以得到信息,数据源支持:IEnumerable接口。


三者比较:

WebForm: IListSource,IEnumerable,IDataSource。

Winform: IListSource

WPF:   IEnumerable


共同点:

由于IListSource的接口有个必须的实现是返回IList,而IList接口本身也有继承自IEnumerable接口。

所以最终的共同点就是都IEnumerable接口,通俗的说就是都支持:List<T>集合这样的数据源。


不同点:(以IDataReader,DataTable,DataSet等通用集合来说明)

WebForm:支持IDataReader,DataTable,DataSet。

Winform:不支持IDataReader, 支持DataTable,DataSet。

WPF:支持IDataReader,不支持DataTable,DataSet。


这里面又有些故事:


Winform:为虾米不支持IDataReader?

对于DataGridView列表控件,其实表格是可以直接修改的,而且修改的值,会直接返改到绑定的数据源上。

可能出于这种性质,对于只读的IDataReader来说,它不太适合DataGridView控件上的读写双需求,所以不支持。


Winform下的DataTable绑定:

对于List<T>,可以方便的修改集合的属性,而对于DataTable,这是个复杂的自定义类,要绑定的东西并不是表的基本属性,而是存在另一个集合DataRowCollection中。

所以,设计人员搞出了:PropertyDescriptor 和ICustomTypeDescriptor等一套规范来实现属性描述和自定义类的取值绑定问题。


WPF:竟然不考虑DataTable支持:

估计双方没沟通好,或者是考虑到新的DataGrid又返朴归真,去掉了写的需求,WPF竟然不支持DataTable, 好在还有个属性DefaultView,可以把信息读到类似集合的DataTableView再去绑定,虽然多转了一步,但也算是勉强支持绑定了。



再说MDataTable

MDataTable是CYQ.Data 数据层框架里极重要的一组类,实现了和数据库间的完整映射,同时也肩负着和各种UI打交道,当然了,没有它我也不可能去研究各种绑定了。

对于自定义MDataTable数据源,在绑定列表控件的这条路上,几年前我研究了很久,后来最稳定的实现为:

public class MDataTable : IDataReader, IEnumerable,IListSource


为何MDataTable在WPF下和DataTable一样失效了?

这里其实有一个和DataTable不同的东西,就是我的自定义数据源继承了IDataReader和IEnumerable,简单的说是支持WPF的。


但是结果为啥绑定无效?

经过代码调试,发现了原来是接口的优先级问题热的祸, IListSource的级别比IEnumerable的先被调用了,结果就走了类似DataTable那一套规则,但那一套规则的属性读取和WPF是无效的,结果就变成了属性绑定,而不是数据行绑定。


解决的办法:

由于IListSource的存在,会导致WPF无法正常绑定,那就把这接口去掉了,发现WPF就正常了。

但是问题又来了,Winform是靠IListSource接口才能绑定,去掉了IListSource,在winform下不正常了。

经过一番深思,考虑了DataTable依靠DataTableView的方式来绑定WPF,我亮出了一招:


11171649-009a377d2f0543f9b8e593741b733ae

说明:

把IListSource接口的实现,分到了另一个类 MDataTableView,注意修饰为内部类,说明对于使用者来说,一切是还是照旧,但是内部在MDataTable.Bind方法调用是有识别当前的平台,如果是Winform,则把对象变更为:new MDataTableView(ref sourceObje)


总结:

虽然各位平时和这些列表控件相依为命,但估计研究绑定机制的,还是比较少的,毕竟需要一定的缘分。

今天的内容就当个参考,待某天缘分来的时候,有需要的时候,再来回顾我这篇文章亦可。






     本文转自cyq1162 51CTO博客,原文链接:http://blog.51cto.com/cyq1162/1270453,如需转载请自行联系原作者


相关文章
|
27天前
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
8 0
|
20天前
|
数据采集 存储 监控
.NET智慧手术室管理平台源码
术前访视记录单、手术风险评估表、手术安全核查表、自费药品或耗材、麻醉知情同意书、麻醉记录单、分娩镇痛记录单、麻醉复苏单、术后镇痛记录单、术后访视记录单、压伤风险评估量表、手术清点记录单、护理记录单、输血护理记录单。
26 0
|
26天前
|
SQL 数据库
使用ADO.NET查询和操作数据
使用ADO.NET查询和操作数据
9 0
|
27天前
深入.net平台的分层开发
深入.net平台的分层开发
39 0
|
2月前
|
SQL 开发框架 .NET
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
67 0
|
4月前
|
Web App开发 开发框架 .NET
asp.net基于WEB层面的云LIS系统平台源码
结合当今各检验科管理及实验室规模的不同状况,充分吸收当今IT科技的最新成就,开发出以高度产品化、功能强大、极易实施操作、并不断升级换代为主要特点的LIS系统。彻底解决检验科的信息孤岛,全面实现全院信息互通互联、高度共享,并为检验科的规范化管理提供了有力工具。
41 0
|
4月前
|
Oracle 关系型数据库 数据管理
.NET医院检验系统LIS源码,使用了oracle数据库,保证数据的隔离和安全性
LIS系统实现了实验室人力资源管理、标本管理、日常事务管理、网络管理、检验数据管理(采集、传输、处理、输出、发布)、报表管理过程的自动化,使实验室的操作人员和管理者从繁杂的手工劳作中解放出来,提高了检验人员的工作效率和效益,降低了劳动成本和差错发生率。
|
4月前
|
人工智能 机器人 C#
Windows编程课设(C#)——基于WPF和.net的即时通讯系统(仿微信)
一款参考QQ、微信的即时通讯软件。采用CS结构,客户端基于.Net与WPF开发,服务端使用Java开发。
|
4月前
|
Web App开发 开发框架 .NET
asp.net基于WEB层面的区域云LIS系统平台源码
asp.net基于WEB层面的区域云LIS系统平台源码
49 1
|
4月前
|
开发框架 小程序 数据可视化
基于.NET、Uni-App开发支持多平台的小程序商城系统 - CoreShop
基于.NET、Uni-App开发支持多平台的小程序商城系统 - CoreShop