[abap] 'REUSE_ALV_GRID_DISPLAY_LVC' 的用法

说明:REUSE_ALV_GRID_DISPLAY_LVC 的用法

REPORT  XXXX.
TYPE-POOLS: slis.
INCLUDE <icon>.

 DATA: u_command TYPE slis_formname VALUE 'USER_COMMAND'.
 DATA: ok_code LIKE sy-ucomm.

  *ALV data declarations
DATA: fieldcatalog TYPE slis_t_fieldcat_alv WITH HEADER LINE.
DATA: it_fieldcat TYPE lvc_t_fcat,     "slis_t_fieldcat_alv WITH HEADER LINE,
      wa_fieldcat TYPE lvc_s_fcat,

      gd_tab_group TYPE slis_t_sp_group_alv,
      gd_layout    TYPE lvc_s_layo,     "slis_layout_alv,
      gd_repid     LIKE sy-repid.

 

* itab definition

TYPES: BEGIN OF t_display.
        INCLUDE STRUCTURE ZTFICO_PPS.
TYPES:   SEL,
        ZNUM TYPE ZNUM,
        field_style TYPE LVC_T_STYL, "FOR DISABLE
      END OF t_display.

 DATA: it_display TYPE STANDARD TABLE OF t_display  WITH HEADER LINE,
      wa_display TYPE t_display.

 

* 屏幕设计略。

* 主程序。

Start-OF-SELCTION.

      SORT it_display by ZNUM EBELN EBELP.   " it_display 为结果输出内表
      PERFORM set_specific_field_attributes.     "  特性设置
      PERFORM build_fieldcatalog CHANGING  it_fieldcat.  " 字段列举
      PERFORM frm_alv_output_data.                " ALV输出

 

* 子程序————————————————————————————————
*&根据条件设置字段是否可编辑
form set_specific_field_attributes .
  DATA ls_stylerow TYPE lvc_s_styl .
  DATA lt_styletab TYPE lvc_t_styl .
  LOOP AT it_display .
    IF it_display-ZFLAG_ZF NE ''.
      ls_stylerow-fieldname = 'ZFLAG_ZF' .
      ls_stylerow-style = cl_gui_alv_grid=>mc_style_disabled.
      "set field to disabled
      APPEND ls_stylerow  TO it_display-field_style.
*可以按上面的代码添加多个字段的是否可修改
      MODIFY it_display .
    ENDIF.
  ENDLOOP.
endform.   

 * 字段列举

 FORM frm_alv_output_data.
  GD_LAYOUT-box_fname  = 'SEL'.
  GD_LAYOUT-stylefname = 'FIELD_STYLE'.
*   GD_LAYOUT-zebra      = 'X'.
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
    EXPORTING
      i_callback_program       = sy-repid
      i_callback_pf_status_set = 'FRM_SET_STATUS'   " 激活标准ALV的GUI状态

      i_callback_user_command  = 'USER_COMMAND'
      i_grid_title             = 'PO采购付款计划表'
      it_fieldcat_LVC          = IT_FIELDCAT
      IS_LAYOUT_LVC            = GD_LAYOUT
      i_save                   = 'X'
*      i_structure_name         = 'ZTFICO_PPS'   " 如果允许,则不用再列举字段,直接显示全部表内容
    TABLES
      t_outtab                 = it_display
    EXCEPTIONS
      program_error            = 1
      OTHERS                   = 2.
ENDFORM.                    "frm_alv_output_data

 


*激活自定义状态栏
FORM frm_set_status USING rt_extab TYPE slis_t_extab.
  CLEAR: rt_extab.
  REFRESH: rt_extab.
  SET PF-STATUS '9001' EXCLUDING rt_extab.
ENDFORM.                    "FRM_SET_STATUS

 

* 用户自定义事件

FORM user_command USING ucomm    TYPE sy-ucomm
                        selfield TYPE slis_selfield.

  data: lo_guid type ref to cl_gui_alv_grid.
  DATA: lr_grid type ref to cl_gui_alv_grid.
  DATA :   lt_index_rows TYPE lvc_t_row.
  DATA : flag_save  TYPE i.
  DATA : lv_index TYPE I.
  CASE ucomm.
    WHEN '&F03' OR 'EXIT' OR 'CANCLE'.
      LEAVE TO SCREEN 0.
    WHEN '&DATA_SAVE'." 保存按钮
*  取得当前alv的grid
      call function 'GET_GLOBALS_FROM_SLVC_FULLSCR'
        IMPORTING
          e_grid = lo_guid.
* 更新数据到内表 (checkbox打钩)
      call method lo_guid->check_changed_data.
*      selfield-refresh = 'X'.
      flag_save = 0.
      LOOP AT it_display WHERE ZFLAG_ZF = 'X' .
        READ TABLE  it_display_save with key  EBELN = it_display-EBELN
                                                                       EBELP = it_display-EBELP
                                                                       BLDAT = it_display-BLDAT
                                                                       ZNUM  = it_display-ZNUM
                                                                       ZFLAG_ZF = ''.
        if sy-subrc = 0 .
          UPDATE ZTFICO_PPS SET ZFLAG_ZF = 'X'
                            WHERE EBELN = it_display-EBELN
                            AND EBELP = it_display-EBELP
                            AND BLDAT = it_display-BLDAT.
          flag_save = flag_save + 1.
        ENDIF.
      ENDLOOP.
      if flag_save > 0 .
        COMMIT WORK.
        MESSAGE '设置支付标识成功!' TYPE 'S'.
      ELSE.
        ROLLBACK WORK.
        MESSAGE '没有修改支付标识或者数据保存失败!' TYPE 'E'.
      ENDIF.
    WHEN '&IC1'.   " 双击显示PO  ME23N
*        取得当前alv的grid
      call function 'GET_GLOBALS_FROM_SLVC_FULLSCR'
        IMPORTING
          e_grid = lr_grid.
      CALL METHOD lr_grid->get_current_cell
        IMPORTING
          e_row     = lv_index.
*      PERFORM frm_click2 USING selfield-fieldname selfield-value..   "根据选择的行字段进行输出
     PERFORM frm_click2 USING lv_index.   "根据选择的行进行输出
  ENDCASE.
ENDFORM. 

 

 * 双击行中指定字段,读取到指定的Parameter ID 中。

 *FORM frm_click2  USING    p_selfield_fieldname
*                         p_selfield_value.
*  IF p_selfield_fieldname CS 'EBELN'."双击的字段 采购订单号
*    SET PARAMETER ID 'BES'  FIELD p_selfield_value."字段的参数ID
*    CALL TRANSACTION 'ME23N' AND SKIP FIRST SCREEN.        "要调用的T_code.
*  ENDIF.
*ENDFORM.                    " FRM_CLICK

 

 * 双击行中任意位置,根据行号读取内表指段到指定的Parameter ID 中。
FORM  frm_click2 USING lv_index_c.
    READ TABLE it_display index lv_index_c.
    if sy-subrc = 0.
    SET PARAMETER ID 'BES'  FIELD it_display-EBELN."字段的参数ID
    CALL TRANSACTION 'ME23N' AND SKIP FIRST SCREEN.        "要调用的T_code.
    ENDIF.
ENDFORM.

 FORM build_fieldcatalog CHANGING  it_fieldcat TYPE lvc_t_fcat.
  PERFORM  frm_fieldcat_init TABLES it_fieldcat
                                USING  'ZNUM' '序号' '0' '6' 'X' '' '' '' 'X'.
  PERFORM  frm_fieldcat_init TABLES it_fieldcat
                                USING  'ZNAME' '供应商名称' '1' '30' 'X' '' '' '' 'X'.
  PERFORM  frm_fieldcat_init TABLES it_fieldcat
                                USING  'EBELN' '采购订单号' '2' '10' 'X' '' '' '' 'X'.
  PERFORM frm_fieldcat_init TABLES it_fieldcat
                                USING 'EBELP' '行项目' '3' '5' 'X' '' '' '' 'X'.
*…… 

  PERFORM  frm_fieldcat_init TABLES it_fieldcat
                                USING  'ZFLAG_ZF' '支付标识' '19' '1' '' '' 'X' 'X' ''.
ENDFORM.                    "build_fieldcatalog

 

* 字段属性设置

 FORM frm_fieldcat_init TABLES t_fieldcat TYPE lvc_t_fcat
                       USING fieldname TYPE C           " 字段名
                             scrtext_m TYPE C           " 标题
                             col_pos   TYPE I           " 所在列
                             outputlen TYPE I           " 输出长度
                             emphasize TYPE C            " 高亮显示
                             key       TYPE C            " 主键
                             checkbox  TYPE C
                             edit      TYPE C
                             fix_column TYPE C           " 固定列
                               .
  DATA: ls_fieldcat TYPE lvc_s_fcat.
  ls_fieldcat-fieldname   = fieldname.
  ls_fieldcat-scrtext_m   = scrtext_m.
  ls_fieldcat-col_pos     = col_pos.
  ls_fieldcat-outputlen   = outputlen.
  ls_fieldcat-emphasize   = emphasize.
  ls_fieldcat-key         = key.
  ls_fieldcat-checkbox    = checkbox.
  ls_fieldcat-edit        = edit.
  ls_fieldcat-fix_column  = fix_column.
  APPEND ls_fieldcat TO t_fieldcat.
  CLEAR  ls_fieldcat.
ENDFORM.                    "frm_fieldcat_init

 

* ALV输出

### 回答1: reuse_alv_grid_display_lvc是一个ABAP函数模块,用于在SAP系统中显示ALV报表。它可以重复使用已经定义的ALV网格显示控件,并将数据填充到网格中。此函数模块可以通过传递不同的参数来控制网格的外观和行为,例如列宽度、排序、筛选和分页等。它是SAP开发人员在开发报表时经常使用的一个重要工具。 ### 回答2: reuse_alv_grid_display_lvc是一种SAP ABAP程序中的函数模块,用于在ALV Grid中显示数据。ALVABAP List Viewer)Grid用于以表格形式显示大量数据,并允许用户对数据进行排序、筛选、编辑以及其他交互式操作。 reuse_alv_grid_display_lvc函数模块一般用于在SAP的ABAP应用程序中的列表显示,该函数将数据集合和ALV的元数据传递给ALV Grid并生成可在SAP GUI中显示的列表。该函数模块的参数可以控制各种风格、排列方式和格式,以便使列表与应用程序的其余部分相匹配。通过使用reuse_alv_grid_display_lvc函数模块,可以快速地生成一个定制的和基于事件驱动的列表GUI,以满足业务需求。 reuse_alv_grid_display_lvc函数模块使用的基本步骤如下: 1. 定义数据表和数据类型,列出要在ALV Grid中显示的每个字段。 2. 创建一个包含字段信息和数据的内表。 3. 调用ALV Grid的数据提取方法,将内表中的数据传递给ALV Grid。 4. 定义一些参数,如is_layout(包含关于呈现实例的设置)、it_events(用于响应事件)等。 5. 最后,调用reuse_alv_grid_display_lvc函数模块。 在使用这个函数模块时,需要注意以下几点: 1. reuse_alv_grid_display_lvc函数模块只在SAP ABAP平台上可用。 2. 函数模块会自动根据数据类型和字段信息创建列表。 3. 大量数据情况下,应考虑采用分页显示,以提高系统性能。 4. 要确保为ALV Grid提供足够的空间,以便将广泛列显示在表格中。 总而言之,reuse_alv_grid_display_lvc函数模块是一种强大的工具,可用于在SAP ABAP应用程序中生成高度可定制的表格列表GUI。通过灵活配置参数,可以生成符合业务需求的列表,并且提供对数据的完整控制,为业务分析和决策提供了更好的支持。 ### 回答3: reuse_alv_grid_display_lvc是一种非常方便的SAP ABAP函数模块,常用于显示ALV表格。ALV 表格是SAP 系统中一个非常重要的组件,常用于显示并编辑大量的数据。该函数模块可以帮助SAP ABAP开发人员在程序设计时能够以一种更为高效便捷的方式使用ALV表格。 使用reuse_alv_grid_display_lvc函数模块可以显著地提高SAP系统中的数据处理速度,同时降低在大型数据集上进行数据处理时的复杂性。不论是对于初学者或者有经验的SAP ABAP开发人员,该函数模块都是非常实用的。 使用该函数模块的时候,可以定义一个内部表作为数据组件,使用ALV Grid Control来展现数据。函数模块提供了非常强大的定制选项,包括自定义排序和筛选规则以及其他加载选项。 使用reuse_alv_grid_display_lvc需要遵循一些指定的规则和步骤。一般情况下,程序员需要在程序开始的时候定义一个TYPE TABLE结构,并使用一个循环结构来循环访问整个数据集。 当使用该函数模块时,需要特别注意内存使用情况。由于ALV表格非常灵活,所以在处理大量数据的时候可能会占用大量内存。因此,开发人员应该注意分配足够的内存以避免出现内存溢出等错误。 总之,reuse_alv_grid_display_lvc是SAP ABAP开发中一种非常实用的工具。使用它能够极大地提高我们在SAP系统中处理数据的效率,并降低数据处理的复杂度。由于其强大的可定制选项和易使用的特性,该函数模块是值得SAP ABAP开发人员深入研究的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值