界面开发遇难题,一招搞定在数据布局控件中编辑聚焦的GridView行

点击获取工具>>

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

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

实现细节
  1. 将DataLayoutControl绑定到可视设计器中的数据源。
  • 如果您的ORM是XPO,请从工具箱中添加XPBindingSource组件。

  • 如果您的ORM是EF或其他库,请从工具箱中添加BindingSource组件。

    • 重建项目。
    • 单击Project>Add New Data Source菜单项。
    • 选择对象数据源类型,然后单击Next。
    • 在列表中选择一个适当的类,然后单击Finish。
    • 将BindingSource分配给DataLayoutControl.DataSource属性。
  1. 检索字段
  2. 选择GridView并订阅FocusedRowChanged 事件。
  3. 使用FocusedRowChangedEventArgs.Row属性值检索聚焦的对象并将其添加到数据源。

XPBindingSource的代码示例

C#
`private void GridView_FocusedRowObjectChanged(object sender, FocusedRowObjectChangedEventArgs e) {
XPBindingSource.DataSource = Session.GetLoadedObjectByKey(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`

阅读 97

推荐阅读