我正在开发一个显示和可编辑ALV的报告。
我设置了PF-STATUS,并添加了一个“ Process”按钮。按下此按钮时,应检索并处理用户在ALV中引入的内容。
这就是我建立自己的ALV的方式:
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
EXPORTING
i_callback_program = sy-repid "program name
i_callback_user_command = 'USER_COMMAND' "user command subroutine name
i_callback_pf_status_set = 'SUB_PF_STATUS'
it_fieldcat = it_fieldcat
i_save = 'X'
TABLES
t_outtab = it_input
EXCEPTIONS
program_error = 1
OTHERS = 2.
但是,我这样做的方式,检索是空的。 我怎么解决这个问题?
下面是有关“处理”的代码片段。
IF r_ucomm EQ '&PROC'.
LOOP AT it_input INTO ls_input.
PERFORM process_data USING ls_input.
ENDLOOP.
ENDIF.
答案 0 :(得分:0)
请删除行刷新it_input。。这是删除it_input的内容,因此检索为空。 您可以使用以下代码,而无需刷新it_input
style={...}
答案 1 :(得分:0)
获取ALV网格实例后,请运行其方法'check_changed_data',如下例所示。
DATA lo_grid TYPE REF TO cl_gui_alv_grid.
IF r_ucomm EQ '&PROC'.
CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'
IMPORTING
e_grid = lo_grid.
IF lo_grid IS NOT INITIAL.
lo_grid->check_changed_data( ).
ENDIF.
LOOP AT it_input INTO ls_input.
PERFORM process_data USING ls_input.
ENDLOOP.
ENDIF.
您可以使用方法“ set_table_for_first_display”直接创建ALV网格,而无需功能模块“ REUSE_ALV_GRID_DISPLAY”。
DATA go_grid TYPE REF TO cl_gui_alv_grid.
CREATE OBJECT go_grid
EXPORTING
i_parent = cl_gui_custom_container=>default_screen.
go_grid->set_table_for_first_display(
CHANGING
it_outtab = it_input
it_fieldcatalog = it_fieldcat ).
...
IF r_ucomm EQ '&PROC'.
go_grid->check_changed_data( ).
LOOP AT it_input INTO ls_input.
PERFORM process_data USING ls_input.
ENDLOOP.
ENDIF.