DevExpress数据源更新后,已聚焦的行如何同步?

DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

在这种情况下,标准方法(将GridControl和DataLayoutControl绑定到同一集合)不起作用,因为CurrencyManager不管理服务器模式数据源。此外,除XPServerCollectionSource以外的所有服务器模式数据源都是只读的。

本文将为大家演示如何使用FocusedRowChanged事件将DataLayoutControl的数据源(XPBindingSource或BindingSource)与已聚焦的行同步。

实现细节

1. 将DataLayoutControl绑定到可视设计器中的数据源。

  • 如果您的ORM是XPO,请从工具箱中添加XPBindingSource组件。重建项目。在Properties窗口选择XPBindingSource.ObjectClassInfo属性,打开下拉列表,然后选择适当的XPO类。将XPBindingSource分配给DataLayoutControl.DataSource属性。
  • 如果您的ORM是EF或其他库,请从工具箱中添加BindingSource组件。重建项目。单击Project>Add New Data Source菜单项。选择对象数据源类型,然后单击Next。在列表中选择一个适当的类,然后单击Finish。将BindingSource分配给DataLayoutControl.DataSource属性。

2. 检索字段。

3. 选择GridView并订阅FocusedRowChanged 事件。

4. 使用FocusedRowChangedEventArgs.Row属性值检索聚焦的对象并将其添加到数据源。

XPBindingSource的代码示例

C#

private void GridView_FocusedRowObjectChanged(object sender, FocusedRowObjectChangedEventArgs e) {
XPBindingSource.DataSource = Session.GetLoadedObjectByKey<ServerSideGridTest>(e.Row);
}

Visual Basic

Private Sub GridView_FocusedRowObjectChanged(ByVal sender As Object, ByVal e As FocusedRowObjectChangedEventArgs)
XPBindingSource.DataSource = Session.GetLoadedObjectByKey(Of ServerSideGridTest)(e.Row)
End Sub


BindingSource的代码示例

C#

private void GridView_FocusedRowObjectChanged(object sender, FocusedRowObjectChangedEventArgs e) {
object obj = DbContext.ServerSideGridTests.Single(e.Row);
BindingSource.Clear();
BindingSource.Add(obj);
}


Visual Basic


Private Sub GridView_FocusedRowObjectChanged(ByVal sender As Object, ByVal e As FocusedRowObjectChangedEventArgs)
Dim obj As Object = DbContext.ServerSideGridTests.Single(e.Row)
BindingSource.Clear()
BindingSource.Add(obj)
End Sub

今天的内容就是这些了,点击“了解更多”获取更多文章教程,更有免费安装包供下载体验!

了解更多
举报
评论 0