7

選択画面で、ユーザーはテーブル名を挿入する必要があり、そのテーブルから最初の 3 つのフィールドを取得して、出力用に ALV に表示する必要があります。チュートリアルを読んでわかったことは、メソッドを呼び出す必要があるということですがcl_alv_table_create=>create_dynamic_table、フィールドカタログの作成方法がわかりません。

DATA: t_newtable   TYPE REF TO data,
      t_fldcat     TYPE lvc_t_fcat,

CALL METHOD cl_alv_table_create=>create_dynamic_table
  EXPORTING
    it_fieldcatalog = t_fldcat
  IMPORTING
    ep_table        = t_newtable.
4

1 に答える 1

9

ユーザーが入力するテーブル名は、データ辞書テーブル (SFLIGHT など) であると想定しています。はいの場合、次のようにフィールド カタログを生成できます。


data : it_tabdescr type abap_compdescr_tab,
     wa_tabdescr type abap_compdescr.
data : ref_table_descr type ref to cl_abap_structdescr.

  ref_table_descr ?= cl_abap_typedescr=>describe_by_name( p_table ).
  it_tabdescr[] = ref_table_descr->components[].
  loop at it_tabdescr into wa_tabdescr.
    clear wa_fieldcat.
    wa_fieldcat-fieldname = wa_tabdescr-name .
    wa_fieldcat-datatype  = wa_tabdescr-type_kind.
    wa_fieldcat-inttype   = wa_tabdescr-type_kind.
    wa_fieldcat-intlen    = wa_tabdescr-length.
    wa_fieldcat-decimals  = wa_tabdescr-decimals.
    append wa_fieldcat to it_fieldcat.
  endloop.

ここで、「p_table」は、テーブル名を含む選択画面パラメーターです。

于 2016-10-10T11:03:41.380 に答える