[代码]基于动态内表的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

以上。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/19225.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论