有时候我们可以把一些字段设置为下拉,比如一些类型,一些字段的值是比较固定的一些值,如性别等。设置为下拉,和设置超级链接是类似的,也是使用了一个内表存放了句柄和对应的值,这个表类型为”LVC_T_DROP”.不过传递给 ALV 的方式有点区别.超级链接是通过方法”SET_TABLE_FOR_FIRST_DISPLAY”
的参数来传递的,而下拉的内表传递需要使用方法”SET_DROP_DOWN_TABLE”. (对OOALV来说)如果我们希望把这个列都设置为下拉,那么我们可以在字段目录中,把控制字段”DRDN_HNDL”指向对应的下拉内表的句柄就可以了。
首先定义句柄内表和对句柄内表操作的工作区:
代码语言:javascript复制*定义下拉表
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”