Snowfun

导航

 

一、ALV简介

1、简介

2、ALV_GRID介绍

3、其它描述

二、开发ALV的基本流程

三、ALV相关开发细节

1、标准ALV与对象ALV的共同开发细节

2、标准ALV开发相关细节

3、对象ALV开发相关细节

四、注意事项

五、附属信息

1、ALV快捷工具栏功能说明(如下图)

2、类型SLIS_FIELDCAT_ALV常用参数说明

3、类型SLIS_T_SORTINFO_ALV常用参数说明

4、类型SLIS_LAYOUT_ALV常用数说明

5、类型SLIS_T_EVENT常用参数说明

6、结构LVC_S_FCAT参数说明(清单观察器控制的字段目录)

7、结构LVC_S_LAYO参数说明(ALV 控制: 布局结构)

8、打印的参数控制请参考结构 [LVC_S_PRNT]

9、排序的参数控制请参考结构[LVC_S_SORT]

11、'REUSE_ALV_GRID_DISPLAY'函数常用参数

12、'REUSE_ALV_LIST_DISPLAY'函数常用参数

13方法"set_table_for_first_display"的参数说明

14方法"REFRESH_TABLE_DISPLAY"的参数说明

六、ALV常见问题

七、示例程序

 

 一、ALV简介

1、简介

ALV――SAP LIST VIEWERSAP中的一种报表方式,这里姑且称之为ABAP表单浏览器,用它可以标准化,简单化R/3系统中的表单,它可以提供给用户一个统一的表单格式及用户接口。ALV是系统的一种网格的显示方式,这种方式带有汇总\排序\筛选等功能,ALV格式的数据是以单元格为单位显示,SAP提供了一套ALV的功能模块,可以对输出报表的样式作修饰,提高报表输出的可读性和功能性,对于动态报表程序是一个很有效率的工具。ALV家族包含3ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV。一般的ALV报表有一个表头,再加上表内容,并附加一些如排序,分类汇总,合计或下载为本地文件等预设功能。ALV报表显示方式基本上有2种,一种是Grid方式,一种是List方式,是分别调用不同的Function来实现。

1)当调用“REUSE_ALV_GRID_DISPLAY”函数时,ALV的显示样式如下:

2)当调用“REUSE_ALV_LIST_DISPLAY”函数时,ALV的显示样式如下:

 

2ALV_GRID介绍

    The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用。在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具。它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏。

 

3、其它描述

        报表的自主开发设计主要逻辑都是依托于选择屏幕上字段,也就是提供给用户让他们得到自己想要结果的选择条件途径。其中最重要的就是必选字段,因为必选字段是取数逻辑的精华所在,他可以很巧妙的限制很多非必要的情况出现,减少开发人员的开发量,还能让用户最直接最快捷的得到与实际业务相关的展现结果。

对于一个报表程序的开发流程,一般都会有几个INCLUDE.(X代表任意自定义字母)

       REPORT ZXXXXXX.

       INCLUDE  ZXXXX_INIT.

       INCLUDE  ZXXXX_F01.

 INCLUDE  ZXXXX_block.

很多都是个人习惯吧,但是有一些习惯,能够让其他人在读程序或者修改程序的时候,很快捷,有规律可循。

INCLUDE ZXXXXX_BlOCK

里面无非就是以下几个部分

INITIALIZATION.(初始化。在所有以下事件块运行之前运行的,只运行一次的事件块)

AT SELECTTION-SCREEN OUTPUT.PBO事件块,即屏幕输出前事件块)

AT SELECTION-SCREEN ON VALUE-REQUEST FOR  选择屏幕字段名称。(自定义搜索帮助事件块)

AT SELECTION-SCREEN.PAI事件块,即屏幕操作后事件块)

START-OF-SELECTION.(程序运行事件块)

 

其它见解:SAP中的程序还是有很多类型的.尤其是类报表程序,有可执行程序(REPORT 开头)还有MODULE POOLPROGARM 开头)2种形式.

ABAP开发属于事件驱动开发,这句话也清晰的解释了SAP程序的必然结构。对于事件驱动,SAP程序就需要是由一个个事件去触发才能够执行的程序,当我们使用SE38去创建1类型的可执行性程序(REPORT 开头)这样的程序,我们可以直接调试,我们会发现,这个程序是按照上面所写的事件块的顺序去依次执行的。它的事件块的顺序是指定好的。所以我们能够按F8,去运行。我们所创建的MODULE POOL就不能去执行,因为它需要用TCODE的去指定运行入口,一般都会在MODULE POOL 里面创建 SCREEN . 在一个SCREEN里就会有两个事件块,分别是PBO PAI。我们使用多个屏幕,或者使用TABLECONTROL控件,再或是使用子屏幕范围控件嵌套各种SUBSCREEN(子屏幕),其中都是需要PAI  PBO 相互联系的,一个屏幕的PAI中,必然后会有一个CALL SCREEN 或者CALL SUBSCREEN ... INCLUDIG....命令去调用另一个屏幕或者子屏幕,然后另一个屏幕先运行PBO,有屏幕上的操作,就执行被操作屏幕的PAI。个人感觉正式这种灵活的编写方式,导致了这种类型(MODULE POOL)的程序不能直接F8,编译器无法获取程序从哪里开始,而TCODE就会指定从哪个屏幕开始。

INCLUDE  ZXXXX_INIT(ZXXXX_TOP):进入程序的第一个INCLUDEINCLUDE 是什么??(CR:就是产生的请求号,也可以理解为一个程序的代码版本,所有的SAP程序都是在D系统(DEVELOPMENT SYSTEM)然后传到Q(测试)系统由顾问进行测试,又不干扰生产系统的程序运行,最后再传到P(生产)系统,覆盖原来的代码,变成修改后代码逻辑)恩,我感觉它是一种封装起来的思想。我研究一下,它单独产生CR,而和它的主程序没有任何关联。这也是必然的,因为INCLUDE是一个全局全系统的声明,一旦你取了一个名字,那么其他人也能够引用使用,这就导致它的修改CR是单独产生的。这里也可以定义程序所需的数据类型和数据对象。

   INCLUDE  ZXXXX_F01:习惯使用PERFROM来封装代码,取有意义的名字,然后把所有的FORM都放在这边。

START-OF-SELECTION中,我们一般都会写以下几个PERFORM,

 PREFORM frm_get_data. (取数逻辑)

 PERFORM frm_alv_layout_build. (创建ALV显示格式)

 PERFORM frm_alv_set_columns.(调用ALV函数)


二、开发ALV的基本流程

 

 第一步:定义ALV所要用到的类型池:TYPE-POOLS: SLIS 

 第二步:定义ALV所要显示的数据对应的内表数据类型及内表数据对象;

 第三步:定义一些显示ALV时所要使用到的变量,例如:

   Data: w_repid  like  sy-repid,  ABAP程序,我们一般取当前程序

        w_callback_ucomm   type slis_formname,   "字符型,功能

        w_print            type slis_print_alv,  "类型组

        w_layout           type slis_layout_alv, "类型组

        w_html_top_of_page type  slis_formname,  "字符型

        w_fieldcat_alv     like line of i_fieldcat_alv, “从上面的数据结构类型引用过来的

        w_excluding        like line of i_excluding,    “同上

        w_events           like line of i_events,       “同上

        w_event_exit       like line of i_event_exit,   “同上

        w_list_comments    like line of i_list_comments.“同上

 第四步:定义选择屏幕 ;

 第五步:声明各个选择屏幕事件块,例如:

   定义initialization部分,在这个部分往往要指定w_repid的值,w_repid = sy-repid

   定义start-of-selection部分,在这通常会调用各种子程序,以下以标准ALV显示为例:

   1)调用一个子程序(通常命名为frm_get_dataXXX(X代表任意自定义字母)),用于获取ALV所要显示的数据 ;例如:

     FORM frm_get_data.

        … …    其它处理逻辑

    SELECT lifnr           "供应商账号
         ktokk           
"账号组
         name1           
"名称1
         name2           
"名称2
       
INTO CORRESPONDING FIELDS OF TABLE it_main
       
FROM zmmjyht003
       
WHERE (l_where)
       .

      … …    其它处理逻辑

     ENDFORM.

   2)调用一个子程序(通常命名为frm_alv_layout_build),用于设置ALV所要显示的样式 ;

    例如:

     FORM frm_alv_layout_build.
       g_layout-zebra = 
'X'.
       g_layout-colwidth_optimize = 
'X'.       "列数据最优化显示
       g_layout-box_fieldname = 
'SELFLAG'.     "表示ALV行项目选中的字段
     
ENDFORM.   

   3)调用一个子程序(通常命名为frm_alv_set_columns),用于完成ALV所要显示的列的相关设置 ;

    例如:

     FORM frm_alv_set_columns.

        REFRESH g_fieldcat_alv.
  
PERFORM frm_set_l_fieldcat USING 1 'LIFNR' '供应商账号'.

     ENDFORM.

     FORM frm_set_l_fieldcat  USING  p_pos p_name p_text.

       DATA: l_fieldcat TYPE slis_fieldcat_alv.
 l_fieldcat-col_pos = p_pos.
 l_fieldcat-fieldname = p_name.
 l_fieldcat-seltext_l = p_text.  

APPEND l_fieldcat TO g_fieldcat_alv.

    ENDFORM

   4)调用显示ALV的函数,例如:REUSE_ALV_GRID_DISPLAY 

     FORM frm_alv_display_data.
       
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
         
EXPORTING
           i_callback_program                = g_repid
           i_callback_pf_status_set          = 
'FRM_STATUS_ALV'
          i_callback_user_command           = 
'FRM_USER_COMMAND_ALV'
          is_layout                         = g_layout
          it_fieldcat                       = g_fieldcat_alv[]
        
TABLES
          t_outtab                          = it_main
        
EXCEPTIONS
           program_error                     = 
1
        
OTHERS                            = 2
            .
  
   ENDFORM

     如果ALV所要展示的列过多时,建议先在数据字典系统中创建相应的结构,这样可免去对输出列表头信息的繁琐编辑处理,代码行也会缩短。只要将上面函数中的it_fieldcat参数替换成i_structure_name,如:I_STRUCTURE_NAME = 'TY_OUT_FILE',注意:此处的TY_OUT_FILE结构必须是数据字典中已经存在的对象

 

  以上步骤,详见“示例程序”部分:示例一(标准ALV)



三、ALV相关开发细节

 1、标准ALV与对象ALV的共同开发细节

 

 

2、标准ALV开发相关细节

 2.1ALV中的各种结构类型注解:

1TYPE-POOLS: slis:用于指定ALV类型组;

2slis_listheader:用于定义top of page的抬头结构;

3slis_t_listheader:用于定义top of page的抬头表

4slis_t_sortinfo_alv:用于指定ALV排序分类合计等信息的数据对象;

   3slis_layout_alv :用于定义布局类型数据对象;

4slis_t_fieldcat_alv WITH HEADER LINE:用于定义ALV列字段相关类型数据

      对象;(slis_t_fieldcat_alv是表字段的整体,slis_fieldcat_alv是某一个字段的内容,将该字段的内容写到 slis_fieldcat_alv后,通过append添加

 

 

 

五、附属信息

1ALV快捷工具栏功能说明

略,见原博客

 

2、类型SLIS_FIELDCAT_ALV常用参数说明

  (用来定义表单中的各个列的相关信息)

(赋值’’中内容必须为大写)
  
fieldname                               对应内表中哪个字段,必须

   Intlen                                  表示可以筛选的长度,如果不输得话有可能在筛选的时候显示不够 长

   emphasize(4)   带有颜色的高亮列

  col_pos = n.                  输出列在ALV中的位置索引值
  

  tabname = ‘FIELDNAME’.      对应的内表字段名(标签名称)

  seltext_s/m/l = ‘列名’.     输出列文本(_s:短文本 _l:长文本)必须

  emphasize = ‘CX10’.    带有颜色的高亮列(其中X=1-7)颜色同format

  hotspot = ‘X’.           作为热点显示可触发鼠标触发事件

  currency = ‘CURRKEY’.    TCURX 中的货币名称

  quantity(3)            计量单位

  qfieldname           参考计量单位的字段名称

  round = n.           四舍五入至小数位数下

  exponent = n.         浮点数的幂指数为n

  key = ‘X’.           关键字段

  icon = ‘X’.          作为图标输出

  symbol = ‘X’.        输出作为符号

  checkbox = ‘X’.      作为复选框输出

  just = SPACE, \'R\', \'L\', \'C\'.   对齐方式

  lzero = ‘X’.          输出前导零

  no_sign = ‘X’.        输出抑制符号

  no_zero = ‘X’.        为输出隐藏零

  edit_mask = SPACE, mask..  输出为mask的模式(为输出编辑掩码)

  

  fix_column = ‘X’.      固定列

  do_sum = ‘X’.        总计列值总和

  no_out = ‘X’.         列不输出

  tech = ‘X’.           该字段为技术字段

  outputlen = n        列的字符宽度为n

  decimals_out = n     能控制小数点的位数为n  

   datatype = C,I,N…        定义数据类型

 

 3、类型SLIS_T_SORTINFO_ALV常用参数说明

  (排序)

   Fieldname        字段名

   Up              升序排列

   Down            降序排列

   Subtot           

 

4、类型SLIS_LAYOUT_ALV常用参数说明

   (用于定义ALV表单的相关格式、属性)

   info_fieldname = \'LINE_COLOR\'.  设置特殊行颜色

(将LINE_COLOR增加到内表字段,写\'CX10\'到特殊行的LINE_COLOR, X为颜色值)

        colwidth_optimize = ‘X’.   优化列宽设置

 no_colhead = \'X\'.         不显示列名

 no_vline = \'X\'.            不显示列间竖线

 zebra       

        f2code = \'&ETA\'.    设置触发弹出详细信息窗口的功能码,这里是双击

 no_vline           这个用来设置列间隔线 

detail_popup        是否弹出详细信息窗口

        detail_titlebar       设置弹出窗口的标题栏

 

 

5、类型SLIS_T_EVENT常用参数说明

DATA: i_events TYPE slis_t_event WITH HEADER LINE. 

  事件: 

  it_events     = i_events[]    

  i_callback_pf_status_set = \'PF_STATUS_SET\'    

  i_callback_user_command  = \'USER_COMMAND\' 

 出口程序触发事件对应子程序:

  FORM PF_STATUS_SET USING rt_extab TYPE slis_t_extab. 

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

ALV标准按钮对应的函数功能码如下:

 

 功能代码:              函数文本:                          图标名称:

&ETA                   细节                        ICON_SELECT_DETAIL

&EB9                 调用报告...                     ICON_TABLE_SETTINGS

&REFRESH              刷新                        ICON_REFRESH

&ALL                 全部选择                      ICON_SELECT_ALL

&SAL                 取消全选                      ICON_DESELECT_ALL 

&OUP                按升序排列                     ICON_SORT_UP

&ODN                按降序排列                     ICON_SORT_DOWN 

&ILT                  设置过滤器                    ICON_FILTER 

&UMC                  总计                         ICON_SUM 

&SUM                  小计...                      ICON_INTERMEDIATE_SUM 

&RNT_PREV           打印预览                      ICON_LAYOUT_CONTROL 

&VEXCEL            Microsoft Excel                   ICON_XLS

&AQW                字处理...                       ICON_WORD_PROCESSING 

%PC                   本地文件  ...                   ICON_EXPORT

%SL                  邮件收件人                      ICON_MAIL

&ABC                 ABC 分析                      ICON_ABC 

&GRAPH                图形                         ICON_GRAPHICS 

&OL0                 更改布局...                      ICON_ALV_VARIANTS 

&OAD                选择格式...                 ICON_ALV_VARIANT_CHOOSE 

&AVE                 保存格式...                  ICON_ALV_VARIANT_SAVE 

&INFO                  信息                      ICON_INFORMATION 

 

6、结构LVC_S_FCAT参数说明(清单观察器控制的字段目录)

 1.字段目录  [Field catalog]

       字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.

       常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTURE LVC_S_FCAT)

2 ROW_POS ALV 控制输出行 (内部使用 

3 COL_POS ALV 控制输出列 列的位置,第几列,例如1,2,…..

4 FIELDNAME ALV 控制内部表字段的字段名称 字段名称

5 TABNAME LVC 标签名称 表名,如果是内表,是1

6 CURRENCY ALV 控制货币单位  

7 CFIELDNAME ALV 控制参考的当前单位的字段名称  

8 QUANTITY ALV 控制计量单位  

9 QFIELDNAME ALV 控制参考计量单位的字段名称  

10 IFIELDNAME ALV 控制内部表字段的字段名称  

11 ROUND ALV 控制: ROUND 值  

12 EXPONENT ALV 控制:流动表示的指数  

13 KEY ALV 控制关键字段 关键字段,前面变蓝色

14 KEY_SEL ALV 控制可以被隐藏的关键列 可以被隐藏的关键列

15 ICON ALV 控制作为图标输出 此列作为图标输出

16 SYMBOL ALV 控制输出作为符号  

17 CHECKBOX ALV 控制作为复选框输出 复选框输出

18 JUST ALV 控制对齐 对齐方式:

\'R\': right justified

\'L\': left justified

\'C\': centered

19 LZERO ALV 控制输出前导零 X\'

20 NO_SIGN ALV 控制:输出抑制符号 X\',不输出符号

21 NO_ZERO ALV 控制为输出隐藏零 X\',隐藏0

22 NO_CONVEXT ALV 控制不考虑输出的转换退出  

23 EDIT_MASK ALV 控制为输出编辑掩码 格式

24 EMPHASIZE ALV 控制带有颜色的高亮列 列的颜色

25 FIX_COLUMN ALV 控制固定列  

26 DO_SUM ALV 控制总计列值 X\',合计

ALV_GRID介绍二(2)

27 NO_SUM ALV 控制没有总计列值 X\' ,没有合计

28 NO_OUT ALV 控制列没有输出 X\' ,隐藏此列

29 TECH ALV 控制技术字段 X\'.也是隐藏,但是有点不一样

30 OUTPUTLEN ALV 控制列的字符宽度 输出的长度

31 CONVEXIT 转换例程  

32 SELTEXT ALV 控制对话功能的列标识符  

33 TOOLTIP ALV 控制列抬头的工具提示  

34 ROLLNAME ALV 控制: F1 帮助的数据元素  

35 DATATYPE ABAP 字典中的数据类型 ABAP 字典中的数据类型

36 INTTYPE ABAP 数据类型(C,D,N,...) ABAP 数据类型(C,D,N,...)

37 INTLEN 以字节计的内部长度 内容的长度

38 LOWERCASE 允许/不允许小写字母 X\' 允许大小写

39 REPTEXT 标题  

40 HIER_LEVEL ALV 控制内部使用  

41 REPREP ALV 控制价值是补充/补充接口的选择标准 

42 DOMNAME 定义域名  

43 SP_GROUP 组代码  

44 HOTSPOT ALV 控制单击敏感 X\',下面出现下划线,响应单击

45 DFIELDNAME ALV 控制数据库中列组的字段名称  

46 COL_ID ALV 控制 ID  

47 F4AVAILABL 字段有输入帮助吗 X\'.此列有搜索帮助

48 AUTO_VALUE ALV 控制自动复制值  

49 CHECKTABLE 表名  

50 VALEXI 固定值存在  

51 WEB_FIELD ALV 控制内部表字段的字段名称  

52 HREF_HNDL 自然数 热点连接的句柄

53 STYLE ALV 控制样式 下面有例子会介绍,比如PUSHBUTTION

54 STYLE2 ALV 控制样式  

55 STYLE3 ALV 控制样式  

56 STYLE4 ALV 控制样式  

57 DRDN_HNDL 自然数 下拉的句柄

58 DRDN_FIELD ALV 控制内部表字段的字段名称 下拉的字段

59 NO_MERGING 字符字段长度 1 相同的值不合并

60 H_FTYPE ALV 树控制功能类型 (总计,平均,最大.最小, ...)  

61 COL_OPT 可选列优化的条目  

62 NO_INIT_CH 字符字段长度 1  

63 DRDN_ALIAS 字符字段长度 1  

64 REF_FIELD ALV 控制内部表字段的参考字段名称  

65 REF_TABLE ALV 控制内部表字段的参考表名称  

66 TXT_FIELD ALV 控制内部表字段的字段名称  

67 ROUNDFIELD ALV 控制带有 ROUND 说明的字段名称 

68 DECIMALS_O ALV 控制输出小数位的编号  

69 DECMLFIELD ALV 控制带有 DECIMALS 说明的字段名称 

70 DD_OUTLEN ALV 控制输出字符长度  

71 DECIMALS 小数点后的位数 设置小数的位数

72 COLTEXT ALV 控制列标题 列标题

73 SCRTEXT_L 长字段标签  

74 SCRTEXT_M 中字段标签  

75 SCRTEXT_S 短字段标签  

76 COLDDICTXT ALV 控制确定 DDIC 文本参考 

77 SELDDICTXT ALV 控制确定 DDIC 文本参考 

78 TIPDDICTXT ALV 控制确定 DDIC 文本参考 

79 EDIT ALV 控制准备输入 输出状态.\'X\'可输入

80 TECH_COL ALV 控制内部使用  

81 TECH_FORM ALV 控制内部使用  

82 TECH_COMP ALV 控制内部使用  

83 HIER_CPOS ALV 控制层次列位置  

84 H_COL_KEY 树控制列名称/项目名称  

85 H_SELECT 标识是否可以选择树控制中的列  

86 DD_ROLL 数据元素 (语义域 

87 DRAGDROPID ALV 控制&放处理拖放对象 

88 MAC 字符字段长度 1  

89 INDX_FIELD 自然数  

90 INDX_CFIEL 自然数  

91 INDX_QFIEL 自然数  

92 INDX_IFIEL 自然数  

93 INDX_ROUND 自然数  

94 INDX_DECML 自然数  

95 GET_STYLE 字符字段长度 1  

96 MARK 字符字段长度 1  

 

7、结构LVC_S_LAYO参数说明(ALV 控制布局结构)

   布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色。参照ALV的控制结构[LVC_S_LAYO],以后的例子我将详细介绍如何设置行颜色和列颜色.

   详细的结构说明

  字段名 描述  Value range

CWIDTH_OPT 最优化宽度 SPACE, \'X\'

SMALLTITLE 小标题,如果设置了这个字段,

则标题与列标题大小一样 SPACE, \'X\'

GRID_TITLE 标题,在网格和工具条之间 最长70个字符

NO_HEADERS 如果被设置,列标题隐藏 SPACE, \'X\'

NO_HGRIDLN 隐藏水平线 SPACE, \'X\'

NO_MERGING 禁用单元格合并 SPACE, \'X\'

NO_ROWMARK 如果被设置,选择列在选择模式

DA的时候隐藏 SPACE, \'X\'

NO_TOOLBAR 隐藏工具条 SPACE, \'X\'

NO_VGRIDLN 隐藏垂直线 SPACE, \'X\'

SEL_MODE 选择模式 SPACE, \'A\', \'B\', \'C\', \'D\'

EXCP_CONDS 合计例外 SPACE, \'X\'

EXCP_FNAME 字段名称带有例外编码 最长30个字符

EXCP_LED 例外作为 LED SPACE, \'X\'

EXCP_ROLLN 例外文档的数据元素 SPACE, \'X\'

CTAB_FNAME 带有复杂单元格颜色编码的字段名称 最长30个字符

INFO_FNAME 带有简单行彩色代码的字段名称 最长30个字符

ZEBRA 可选行颜色,如果设置了,出现了间隔色带 SPACE, \'X\'

NO_TOTLINE 没有总计 SPACE, \'X\'

NUMC_TOTAL 可以对NUMC字段进行合计 SPACE, \'X\'

TOTALS_BEF 总计输出在第一行,小计在新的值之前 SPACE, \'X\'

STYLEFNAME 设置单元格,比如PUSHBUTTON 最长30个字符


8、打印的参数控制请参考结构 [LVC_S_PRNT]

 9、排序的参数控制请参考结构[LVC_S_SORT]

 10、过滤的参数控制请参考结构[LVC_S_FILT]

 

11'REUSE_ALV_GRID_DISPLAY'函数常用参数

   CALL FUNCTION \'REUSE_ALV_GRID_DISPLAY\' 

      EXPORTING 

           i_interface_check        = \'\'                      接口一致性检查 

           i_callback_program       = sy-repid                当前程序名 

           is_layout                = layout                  输出样式 

           it_fieldcat              = fieldcat[]              字段定义描述表 

           i_callback_pf_status_set = \'PF_STATUS_SET\'         触发事件调用子程序 

       i_callback_user_command  = \'USER_COMMAND\'          鼠标事件操作子程序 

           it_events                = i_events[]              出口程序触发事件 

           i_callback_html_top_of_page  = \'ALV_TOP_OF_PAGE\'   ALV输出表头设置 

           i_grid_settings = wl_lvc_s_glay                    打印表头设置 

           it_sort = sortable[]                               排序设置 

 TABLES 

        t_outtab                 = ig_out 

     EXCEPTIONS 

        program_error            = 1 

        OTHERS                   = 2. 

 

 

 12'REUSE_ALV_LIST_DISPLAY'函数常用参数

 

 

 13、方法"set_table_for_first_display"的参数说明

   _BUFFER_ACTIVE 如果方法调用是静态的,可以设置这个标记,这表示,如果每次显示ALV都是

相同的字段目录.既然这样,那么字段目录会被放到一个特殊的缓存里,

这样加速了ALV的显示

I_STRUCTURE_NAME 输出数据参考的数据字典的结构名,例如\'SFLIGHT\'.如果指定了这个参数,字段

目录会自动生成,下面的参数IT_FIELDCATALOG不需要传值.

IS_VARIANT 决定布局显示的变式

I_SAVE 决定用户是否可以保存变式:

\'X\' 只能保存全局变式

\'U\' 只能保存特定变式

\'A\' 都可以保存

SPACE 不可以保存变式

I_DEFAULT 决定用户是否可以定义默认的布局:

\'X\' 可以定义默认布局,这个参数是默认的

SPACE 不可以定义默认布局

IS_LAYOUT 布局参数,传递布局控制的一些信息

IS_PRINT 后台打印属性的参数

IT_SPECIAL_GROUPS 如果在字段目录中,一些字段通过SP_GROUP被分组在一起.我们就必须为这些

组传递一个组的文本内表进去

IT_TOOLBAR_EXCLUDING 需要隐藏的标准的按钮的内表

IT_HYPERLINK 为每个句柄分配了超连接的内表,LVC_S_HYPE中的HREF存放了超连接的地址,

HANDLE指定了句柄,使用这些句柄,你可以在GRID中使用超连接

IT_ALV_GRAPHICS 比较复杂,没有用过,意思好象是可以在图表中显示ALV.

IT_OUTTAB 输出数据存放的内表,数据都是存放在这个内表里

IT_FIELDCATALOG 字段目录

IT_SORT 排序的标准

IT_FILTER 过滤的标准

 

14方法"REFRESH_TABLE_DISPLAY"的参数说明

IS_STABLE 刷新的稳定性,有2个参数,一个是行,一个是列.如果设置了相应的值,

那么对应的行,或者列,在刷新的时候,将会保持稳定,就是滚动条保持不动.

I_SOFT_REFRESH 这个参数只是在异常情况下被使用,如果设置了这个参数,任何创建的合计,

任何排序次序,任何为了显示数据而设置的过滤都将保持不变.这个是非常

有意义的.例如:当然你没有修改数据内表里的数据而想刷新ALV,仅仅只是

改变一下布局和字段目录.

 

 

六、ALV常见问题

 1、当为报表程序创建完TCODE后,如果新创建的报表程序没有激活的话,即使在命令域中输入了对应的TCODE,也无法导入到报表程序对应的运行界面,而应该先激活报表程序,这样TCODE才能起作用。

 

 

http://www.cnblogs.com/VerySky/articles/2192401.html

posted on 2012-09-27 13:59  Snowfun  阅读(1950)  评论(0)    收藏  举报