0

我使用带有 TPrototypeBindSource 的业务类。我将使用 CustomFormat 连接 2 个字段。我来的是 TBindSourceDB,但不是 TPrototypBindSource。

我使用 TEdit 和 TLinkControlToField。

如果我使用 : %s + " text" => 它可以正常工作。当我将它与 TBindSourceDB 一起使用时,效果很好

%s + " - " + Self.Owner.FieldByName('Enseigne').text

但是当我使用 TPrototypeBindSource 时,我不明白如何访问数据。

在此处输入图像描述

在此处输入图像描述

你能给我用业务类绑定连接 2 个字段的语法吗?

4

1 回答 1

0

我想我会再回答一次,因为你似乎对我的第一个答案没有太大的热情。

在解决你的问题之前,让我们做一个小实验。例如,在一个具有持久字段 FieldA 和 FieldB 的 DataSet 的项目中,设置一个 BindSourceDB 和 BindingList 并添加两个 TLinkControlToField 以将这些字段链接到两个 TEdit,即 edFieldA 和 edFieldB。

测试它是否按预期工作,然后添加另一个 TEdit、edOther 和另一个 TLinkControlToField、LinkControlToField3。将其控件设置为 edOther,将 DataSource 设置为 BindSourceDB,将其 FieldName 设置为 FieldA。将其 CustomFormat 设置为

Name

编译运行,你会发现edOther显示了FieldA的Field组件的名称,DataSetFieldA或类似的名称。显然,LiveBinding 的表达式求值器正在使用 FieldA 的 TField 组件作为它用来识别Name所引用的属性的“范围”。

现在,替换NameOwner.Name

并且在运行时 edOther 应该显示Form1或类似,因为持久性字段由其包含的表单或数据模块拥有。因此,引用 Owner.Name 扩大了Format可以解析表达式中的标识符并提取其值的范围。

因此,使用 BindSourceDB 作为链接的数据源,您可以将其设置CustomFormat为相当复杂的东西,例如

LowerCase(Owner.DataSet.IndexFieldNames) + ' ' + Owner.DataSet.FieldByName('ID').Text

不幸的是,这不适用于PrototypeBindSource.

继续我们的实验,使用 PrototypeBindSource 设置一个项目,该项目具有两个字段 FieldA 和 FieldB 以及三个 TEdit,如前所述。请注意,这一次,如果您尝试将CustomFormatLinkControlToField3 设置为Name您将收到错误消息“找不到名称”,我认为是因为 LB 机器无法解析对名称的引用,因为 TPropotypeBindSource 中的字段的抽象实现.

然而,一切都没有丢失。删除 LinkControlToField3,而是向窗体的 BindingList 添加一个 BindExpression。

将 BindExpression 的 ControlComponent 设置为edOther,将其 ControlExpression 设置为 ,Text并将其 SourceComponent 设置为Form1

完成后,在 SourceExpression 中,我们可以使用像这样的表达式来引用 Form1 及其组件的属性

edFieldA.Text + ':' + edFieldB.Text

这对我来说很好。

我还没有设法找出的一件事是 SourceExpression 不能包含LowerCase. 然而,这很容易解决,通过向MyLowerCaseForm1 添加一个函数,LB 对此非常满意。

所以,我认为这回答了您关于如何将内容连接到两个控件(或字段)的问题。就个人而言,我仍然更喜欢使用业务对象的串联属性,但是 ymmv.

于 2017-02-22T20:04:44.227 回答