从可编辑的ALV中检索内容

时间:2018-12-19 16:25:26

标签: grid sap abap alv

我正在开发一个显示和可编辑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.

2 个答案:

答案 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.