ALV中下拉列表列的实现

有时候我们可以把一些字段设置为下拉,比如一些类型,一些字段的值是比较固定的一些值,如性别等。设置为下拉,和设置超级链接是类似的,也是使用了一个内表存放了句柄和对应的值,这个表类型为”LVC_T_DROP”.不过传递给 ALV 的方式有点区别.超级链接是通过方法”SET_TABLE_FOR_FIRST_DISPLAY”

的参数来传递的,而下拉的内表传递需要使用方法”SET_DROP_DOWN_TABLE”. (对OOALV来说)如果我们希望把这个列都设置为下拉,那么我们可以在字段目录中,把控制字段”DRDN_HNDL”指向对应的下拉内表的句柄就可以了。

首先定义句柄内表和对句柄内表操作的工作区:

*定义下拉表

DATA:gt_drp TYPE lvc_t_drop.

DATA:gs_drp TYPE lvc_s_drop.

*向下拉表中填充数据,handle值相同的为一组下拉。

FORM prepare_drilldown_values.

gs_drp-handle = ‘1′ .

gs_drp-value = ‘JFK-12′ .

APPEND gs_drp TO gt_drp .

gs_drp-handle = ‘1′ .

gs_drp-value = ‘JSF-44′ .

APPEND gs_drp TO gt_drp .

gs_drp-handle = ‘1′ .

gs_drp-value = ‘KMDA-53′ .

APPEND gs_drp TO gt_drp .

gs_drp-handle = ‘1′ .

gs_drp-value = ‘SS3O/N’ .

APPEND gs_drp TO gt_drp .

ENDFORM.                    ”prepare_drilldown_values

*定义字段目录中,对DRDN_HNDL进行设置,设置为1的话,该字段的下拉组为gt_drp中handle为1的组:

form fc.

…..

‘S’ ‘TABNAME’   ‘GT_MARA’ ,

”  ’SCRTEXT_M’ ‘DRP’ ,

”  ’DRDN_HNDL’ ‘1′,

”  ’EDIT’      ’X’,

‘E’ ‘FIELDNAME’ ‘DRP’ .

…..

endform.

然后在调用alv之前:

CALL METHOD gs_alv->set_drop_down_table

EXPORTING

it_drop_down = gt_drp.

CALL METHOD gs_alv->set_table_for_first_display

EXPORTING

is_layout            = gs_layout

it_toolbar_excluding = g_toolbar

it_hyperlink         = gt_hype

CHANGING

it_outtab            = gt_mara[]

it_fieldcatalog      = gt_fieldcat.

效果如下:

如果是某个单元格设置为下拉,那我们就需要在数据显示的内表中增加一个句柄字段(如果是有多个不同的字段需要设置下拉,可以增加多个字段),同时得在字段目录里设置”DRDN_FIELD”

你可能感兴趣的:(ALV中下拉列表列的实现)