ルックアップ コントロール
この記事では、コントロールの検索動作を有効にする方法について説明します。 また、複数選択ルックアップを作成する方法について説明し、現在サポートされていないルックアップ シナリオの概要について説明します。
コントロールのルックアップ動作を有効化
拡張データ型にバインドされたコントロール
拡張データ型プロパティ セット (実行中の FormDataSource が無い) を持つコントロールは、次の条件の下で検索を行います。
- EDT にはそのテーブル リレーションまたはテーブルの参照ノードが設定されているかどうか。
- FormHelp プロパティが設定されている場合 (カスタム ルックアップ)、ルール #1 を true に設定する必要はありません。
- コントロールでルックアップまたは lookupReference メソッドが上書きされている場合。 このルールは、完全な非連結コントロール (EDT、フィールド、またはデータ メソッドなし) にも適用されます。 この条件には、registerOverrideMethod などの上書きも含まれます。
フォーム データ ソースにバインドされたコントロール
データ ソースにバインドされたコントロールは、次の条件の下で検索されます。フィールド バインド
"lookup" または "lookupReference" (参照コントロール) メソッドが上書きされます。
- FormDataSource フィールドでルックアップまたは lookupReference メソッドが上書きされている場合。
- コントロールでルックアップまたは lookupReference メソッドが上書きされている場合。
- この条件には、registerOverrideMethod などの上書きも含まれます。
このフィールドに EDT がある場合、"拡張データ型にバインドされたコントロール" セクションのルール #2 が適用されます。
バインディング フィールドは、DBFGetRef ルールごとにリレーションをマップします。
- 高レベルのルール:
フィールドを支持する EDT 関係が存在し、テーブル関係ノードが入力され、Ignore EDT Relations がフィールド上で false である場合、その関係が使用されます (ルックアップがある)。
フィールドに対してリレーション マッピングが使用され、任意の固定フィールド リンク条件が満たされている場合は、そのリレーションが使用されます (ルックアップがある)。
- 検証は「はい」にする必要があります。
次の場合に発生する 移行された EDT 関係の特殊なケースに注意してください。
- フィールドは、関係ノードが設定される EDT によってサポートされます。
- フィールドは、「EDTRelation」設定を「はい」にするテーブル関係によってサポートされます。
- テーブル関係リンクは SourceEDT が適切な EDT に設定されています。
また、IgnoreEDTRelation がフィールド上で true にセットされているケースを持つことができます。このケースでは、このセクションのルール #3.1.2 が true である場合にのみルックアップが発生します。
- 高レベルのルール:
データ メソッド バインド
- データ メソッドの戻り値が EDT である場合、"拡張データ型にバインドされたコントロール"セクションのルール #1 と #2 が適用されます。
- コントロールでルックアップまたは lookupReference メソッドが上書きされている場合。
- この条件には、registerOverrideMethod を使用した上書きも含まれます。
複数選択のルックアップ
複数選択ルックアップを構築するために利用可能なシステム フォーム
現在、複数選択ルックアップを作成するためのシステム フォームが 2 つあります。
- SysLookup: 列挙に基づいて複数選択します。
- SysLookupMultiselectGrid: データの収集に基づいて複数選択します。
SysLookupMultiselect フォームの変更点とは
SysLookupMultiselect は、Microsoft Dynamics AX 2012 で廃止の対象としてマークされ、削除されました。 複数選択のルックアップ シナリオでこのフォームを使用する場合、SysLookupMultiselectGrid を使用するように移行する必要があります。 例については、チュートリアル LookupMultiSelectGrid のフォームを参照してください。
検索シナリオはサポートされていません
ルックアップ ボタンが使用されているときの複数のルックアップ フォームを作成しています
ルックアップ ボタンを使用して複数のルックアップ フォームを作成する場合にエラーが発生する可能性があります。 たとえば、"ルックアップ" メソッドを上書きして新しいルックアップ フォームを作成しても、"スーパー" (別のルックアップ フォームを作成します) も呼び出します。
SelectedControl() を使用してルックアップをホストしているコントロールを決定
ルックアップをホストしているコントロールを決定する SelectedControl() の使用はサポートされていません。 場合によっては動作しますが、他の場合には失敗します。 たとえば、曖昧性解消ルックアップでは、コントロールを離れる行為は、曖昧性解消ルックアップをトリガーすることであるため、親フォーム上でコントロールは選択されていません。。 SelectedControl() を使用する代わりに、ルックアップをホストしているコントロールを取得するいくつかの方法があります。
ルックアップ フォームの「selectTarget」を確認してください。
FormStringControl selectTarget = formRun.selectTarget();
ルックアップ フォーム引数の「callerFormControl」を確認してください。 SysTableLookup::getCallerControl(Args args) はその呼び出しをカプセル化します。
FormStringControl argsCallerFormControl = args.callerFormControl();
ルックアップ フォーム インスタンスがカーネルによって自動的にスピン アップされる場合、selectTarget および callerFormControl が自動的に設定されます。 フォーム インスタンスがアプリ コードで作成される場合、これらを次のように手動で設定できます。
public void lookup()
{
Args args = new Args(formStr(<formName>));
args.caller(element);
args.callerFormControl(this);
FormRun formRun = classfactory.formRunClass(args);
formRun.init();
this.performFormLookup(formRun);
}
ルックアップ ボタンを使用する際のスライダーのダイアログ (ルックアップ フォームの代わりに) を作成しています
ルックアップ ボタンを使用すると、ルックアップ コントロールによってルックアップ フォームを開く必要があります (スライダー ダイアログまたはその他の種類のフォームではありません)。 この機能における 1 つ目の理由は、製品の整合性を保つことです。 2 番目の重要な理由は、ルックアップからスライダー ダイアログを開くことは、ルックアップの新しい先行入力機能と互換性がないことです。