C#中“类似GridView等控件”的前台显示与后台数据变化之间的关系

时间:2021-11-10 00:21:53

  最近用dev的treelist,gridcontrol等控件,这些控件显示数据都需要进行DataTable等数据源的绑定,而经理又要求可以随时更改其中的内容,刚开始总是不断的刷新控件、更新控件的数据源(我这里就需要从数据库重新取数据)感觉特别麻烦。

  这两天在更改代码时发现了一些我觉的很快捷的地方,在这里提一下:

※这里我的数据源都是以DataTable来做的

  1、当从数据库取出数据并赋予datatable之后,接下来只要不再去连接数据库,这时对datatable的所有操作都不会影响数据库内的数据。

  2、把上一步获取的datatable绑定为控件的数据源(假设为treelist控件)之后,在窗口界面上对treelist的控件所做的所有更改,比如更改节点的名字、移动节点的位置等,都会直接反应到它所绑定的datatable中,同时我们在代码中对datatable中的某一行数据进行更改时(不是重新从数据库取数据),不需要重新刷新treelist控件会直接把你做的数据更改反应到界面上。【这里的意思就是在前台,我们可以随意操作控件并更改各种地方,然后这些更改会实时反应到它后台绑定的datatable中,我们就可以取到实时更改后的数据,从而便于我们进行其他操作】

  3、数据库的更新。知道了datatable的实时更新特点,我们在对控件完成了所有的更改操作以后,我们在单独进行一次数据库连接,把datatable的数据更新入数据库就可以实现前后前数据的一致。

  4、在用DataTable给前台控件gridview绑定数据之后,如果用代码更改了datatable中的数据关系【这里指为gridview添加了子表关系】,这时只有刷新控件的结构(仅仅refreshDataSource是不行的)才能将更新的部分显示出来。

  5、这里我以gridview控件的子表使用来做说明:

我的过程是给gridview动态绑定数据,同时在代码中通过事件的激发为gridview开启子表功能,然后绑定数据。这时虽然数据源刷新了,但是控件上并不能即时显示子表的“加号”如图中的对比:

像这种情况,,只有刷新gridview的结构才能显示出来,该控件的其他refresh方法都不行,我采用的刷新结构方法是:gridview.BestFitColumn(),这就能达到即时更改数据源同时即时刷新显示的目的。