zoukankan      html  css  js  c++  java
  • [代码]基于动态内表的ALV

    SAP项目有会要动态显示ALV列的需求,就是ALV的列数量不固定,这是就要用到动态内表的技术,动态内表通过cl_alv_table_create=>create_dynamic_table来创建。

    完整代码:

    REPORT ZTEST_ALV_DYNAMIC.
    *-------------ALV 相关--------------------------
    DATA: wa_layo TYPE lvc_s_layo.
    DATA: wa_fcat TYPE lvc_s_fcat,
          it_fcat TYPE lvc_t_fcat.
    
    DATA  it_scol TYPE lvc_t_scol.
    
    DATA: g_grid TYPE REF TO cl_gui_alv_grid.
    
    FIELD-SYMBOLS: <dyn_table> TYPE STANDARD TABLE,
                   <dyn_wa>,
                   <dyn_field>.
    
    DATA: dy_table TYPE REF TO data,
          dy_line  TYPE REF TO data.
    
    DATA: colname(10),
          index(2).
    
    * 列数
    PARAMETERS: col TYPE i.
    
    CLEAR: it_fcat.
    * 根据条件动态生成列catalog
    DO col TIMES.
      index = index + 1.
      CONCATENATE 'COL' index INTO colname.
      PERFORM frm_add_fcat USING:
             colname 'C' '描述' '100'.
    ENDDO.
    
    * 根据it_fact生成动态表
    CALL METHOD cl_alv_table_create=>create_dynamic_table
      EXPORTING
        it_fieldcatalog = it_fcat
      IMPORTING
        ep_table        = dy_table.
    
    ASSIGN dy_table->* TO <dyn_table>.
    
    CREATE DATA dy_line LIKE LINE OF <dyn_table>.
    
    ASSIGN dy_line->* TO <dyn_wa>.
    
    * 给表字段赋值
    CLEAR: index.
    DO col TIMES.
      index = index + 1.
      CONCATENATE 'COL' index INTO colname.
      ASSIGN COMPONENT colname OF STRUCTURE <dyn_wa>  TO <dyn_field>.
      <dyn_field> = '列数据'.
    ENDDO.
    APPEND <dyn_wa> TO <dyn_table>.
    
    * 相当于给内表放入两条数据
    CLEAR: index.
    DO col TIMES.
      index = index + 1.
      CONCATENATE 'COL' index INTO colname.
      ASSIGN COMPONENT colname OF STRUCTURE <dyn_wa> TO <dyn_field>.
      <dyn_field> = '列数据'.
    ENDDO.
    APPEND <dyn_wa> TO <dyn_table>.
    
    CLEAR: wa_layo.
    wa_layo-zebra = 'X'.
    wa_layo-cwidth_opt = 'X'.
    
    CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
      EXPORTING
        i_callback_program = sy-repid
        is_layout_lvc      = wa_layo
        it_fieldcat_lvc    = it_fcat
      TABLES
        t_outtab           = <dyn_table>
      EXCEPTIONS
        program_error      = 1
        OTHERS             = 2.
    IF sy-subrc <> 0.
      MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
      WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
    ENDIF.
    
    *&---------------------------------------------------------------------*
    *&      Form  frm_add_fcat
    *&---------------------------------------------------------------------*
    *       text
    *----------------------------------------------------------------------*
    *      -->VALUE1     text
    *      -->VALUE2     text
    *      -->VALUE3     text
    *      -->VALUE4     text
    *----------------------------------------------------------------------*
    FORM frm_add_fcat USING value1 value2 value3 value4.
      wa_fcat-fieldname = value1.
      wa_fcat-inttype = value2.
      wa_fcat-reptext = value3.
      wa_fcat-intlen   = value4.
      APPEND wa_fcat TO it_fcat.
      CLEAR: wa_fcat.
    ENDFORM.                    "frm_add_fcat

    运行结果:

    选择画面上输入alv显示的列数目,

    2017-03-06_10-11-07

    运行后,

    2017-03-06_10-11-39

    以上。

  • 相关阅读:
    socket错误码获取
    代码整洁之道读书笔记函数
    算法学习之堆排序
    包含与继承区别
    提高 LayerBacked Memory Use
    RenderBuffer
    算法学习之快速排序
    NSTimer
    DNS and BIND ... (转载) zhumao
    Samba学习笔记(转载) zhumao
  • 原文地址:https://www.cnblogs.com/datie/p/11435674.html
Copyright © 2011-2022 走看看