ALV详细字段介绍以及一些用法

合集下载

ALV详解_SAP精华篇

ALV详解_SAP精华篇

ALV详解_SAP精华篇一.ALV介绍The ALV Grid Control (ALV = S A P L ist V iewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用.SAP提示: 在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具,然而,目前这个功能只在实验计划中使用,还没有向客户发布.下面是一个ALV GRID的图片:它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏.ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV.二.ALV GRID CONTROL (ALV网格控制器)ALV GRID CONTROL使用了控制器技术以实现艺术性的屏幕显示,象所有的控制器一样,ALV GRID CONTROL通过系统中的一个全局的类提供了方法,以响应它的动作.使用了ABAP的对象以后,列表是通过ALV的一个实例(INSTANCE)来显示的,程序员可以使用ABAP对象的事件管理.三.ALV GRID CONTROL 实例ALV GRID实例的定义,参照CL_GUI_ALV_GRID类data ALV_GRID1 type ref to cl_gui_alv_grid.ALV GRID继承结构:四、ALV GRID相关的几个控制结构1.字段目录[Field catalog]字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTURE LVC_S_FCAT)2.布局控制[layout]布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.参照ALV的控制结构[LVC_S_LAYO],以后的例子我将详细介绍如何设置行颜色和列颜色.详细的结构说明3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SORT]过滤的参数控制请参考结构[LVC_S_FILT]这里不再一一解释,进入中文版本,里面应该也有解释的,虽然一些不是很清楚.五.编写简单的ALV程序.首先这里就不详细介绍DIALOG的用法了.OO的ALV GRID必须存在于一个容器当中,就是FUNCTION的ALV,其实也是一样的,底层也是使用CL_GUI_ALV_GRID这个类的.首先ALV的显示需要有几个先决条件.1,字段目录,这个是必须的,如果没有这个参数,参考一个数据字典也是可以的,就是参数I_STRUCTURE_NAME.2.存放数据的内表,最好内表的结构和字段目录是一致的,否则可能会出现一些无法预知的错误,当然你说我非要不一样,那也不一定会出现错误.我建议是最好一样的.这2个是必须的,布局的话,应该是可以不设置的,使用默认的就可以了.第一步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量.DATA:WCL_CONTAINER TYPE REF TO CL_GUI_CUSTOM_CONTAINER,WCL_ALV TYPE REF TO CL_GUI_ALV_GRID .*--- 存放字段目录的内表DATA gt_fieldcat TYPE lvc_t_fcat .*--- 布局结构DATA gs_layout TYPE lvc_s_layo .*----声明需要显示的内表(以SFLIGHT为例)DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA END OF gt_list .第二步: 创建ALV这个对象,它的父组件是那个容器.在PBO中写入如下代码:PROCESS BEFORE OUTPUT .MODULE display_alv .创建DISPLAY_ALV的MODULE后,写下如下代码:MODULE display_alv OUTPUT .PERFORM display_alv .ENDMODULE .在FORM DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建:IF WCL_ALV IS INITIAL .CREATE OBJECT: WCL_CONTAINEREXPORTINGCONTAINER_NAME = 'ALV_CON'.CREATE OBJECT WCL_ALVEXPORTINGI_PARENT = WCL_CONTAINER.*-----准备获取字段目录PERFORM prepare_field_catalog CHANGING gt_fieldcat .*-----设置布局PERFORM prepare_layout CHANGING gs_layout .*-----显示ALVCALL METHOD gr_alvgrid->set_table_for_first_display EXPORTING* I_BUFFER_ACTIVE =* I_CONSISTENCY_CHECK =* I_STRUCTURE_NAME =* IS_VARIANT =* I_SAVE =* I_DEFAULT = 'X'is_layout = gs_layout* IS_PRINT =* IT_SPECIAL_GROUPS =* IT_TOOLBAR_EXCLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_list[]it_fieldcatalog = gt_fieldcat* IT_SORT =* IT_FILTER =EXCEPTIONSinvalid_parameter_combination = 1program_error = 2too_many_lines = 3OTHERS = 4 .ELSE .*----刷新ALVCALL METHOD gr_alvgrid->refresh_table_display * EXPORTING* IS_STABLE =* I_SOFT_REFRESH =EXCEPTIONSfinished = 1OTHERS = 2 .IF sy-subrc <> 0.*--异常处理ENDIF.ENDIF .方法"set_table_for_first_display"的参数说明方法"REFRESH_TABLE_DISPLAY"的参数说明第三步,获取要显示数据的字段目录.有两种方式.1.手动创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat .DATA ls_fcat type lvc_s_fcat .ls_fcat-fieldname = 'CARRID' .ls_fcat-inttype = 'C' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Carrier ID' .ls_fcat-seltext = 'Carrier ID' .APPEND ls_fcat to pt_fieldcat .CLEAR ls_fcat .ls_fcat-fieldname = 'CONNID' .ls_fcat-ref_table = 'SFLIGHT' .ls_fcat-ref_table = 'CONNID' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Connection ID' .ls_fcat-seltext = 'Connection ID' .APPEND ls_fcat to pt_fieldcat .ENDFORM .2.半自动的创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat . DATA ls_fcat type lvc_s_fcat .CALL FUNCTION 'LVC_FIELDCATALOG_MERGE'EXPORTINGi_structure_name = 'SFLIGHT'CHANGINGct_fieldcat = pt_fieldcat[]EXCEPTIONSinconsistent_interface = 1program_error = 2OTHERS = 3.IF sy-subrc <> 0.*--Exception handlingENDIF.LOOP AT pt_fieldcat INTO ls_fcat .CASE pt_fieldcat-fieldname .WHEN 'CARRID' .ls_fcat-outpulen = '10' .ls_fcat-coltext = 'Airline Carrier ID' .MODIFY pt_fieldcat FROM ls_fcat .WHEN 'PAYMENTSUM' .ls_fcat-no_out = 'X' .MODIFY pt_fieldcat FROM ls_fcat .ENDCASE .ENDLOOP .ENDFORM .第四步,设置布局FORM prepare_layout CHANGING ps_layout TYPE lvc_s_layo.ps_layout-zebra = 'X' .ps_layout-grid_title = 'Flights' .ps_layout-smalltitle = 'X' .ENDFORM. " prepare_layout第五步,排除不需要的标准按钮(可选,这个是第一种方法,还有另外一种,在添加自定义的按钮的时候介绍)在你的ALV上,如果你想排除一些你不想要的标准按钮,你可以把需要排除的按钮填入到表UI_FUNCTIONS中,然后传给set_table_for_first_display方法的参数"IT_TOOLBAR_EXCLUDING".这些按钮的功能码一般都可以通过查看类cl_gui_alv_grid的常量属性中获取到,或者自己加个断点,在after_user_command事件中.如果你要隐藏全部的工具条,你可以把layout中的no_toolbar设置为"X".FORM exclude_tb_functions CHANGING pt_exclude TYPE ui_functions .DATA ls_exclude TYPE ui_func.ls_exclude = cl_gui_alv_grid=>mc_fc_maximum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_minimum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_subtot .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_average .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_subtot .ENDFORM .按照上面的步骤,一个ALV的DEMO基本可以创建了.下面我们将讲述一些功能.功能一:在第一次显示以后,修改字段目录和布局.在运行的时候,很有可能需要在显示之后,需要设置一个新的布局或者字段目录.有下面这些方法去实现.字段目录: get_frontend_fieldcatalogset_frontend_fieldcatalog布局:get_frontend_layoutset_frontend_layout使用这些方法,你在执行的任何时候,可以获取这些内容,然后修改他们.DATA ls_fcat TYPE lvc_s_fcat .DATA lt_fcat TYPE lvc_t_fcat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_frontend_fieldcatalogIMPORTINGet_fieldcatalog = lt_fcat[] .LOOP AT lt_fcat INTO ls_fcat .IF ls_fcat-fieldname = 'PAYMENTSUM' .ls_fcat-no_out = space .MODIFY lt_fcat FROM ls_fcat .ENDIF .ENDLOOP .CALL METHOD gr_alvgrid->set_frontend_fieldcatalogEXPORTINGit_fieldcatalog = lt_fcat[] .CALL METHOD gr_alvgrid->get_frontend_layoutIMPORTINGes_layout = ls_layout .ls_layout-grid_title = 'Flights (with Payment Sums)' .CALL METHOD gr_alvgrid->set_frontend_layoutEXPORTINGis_layout = ls_layout .功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构LVC_T_SORT创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_for_first_display这个方法的IT_SORT参数来初始化一个排序.FORM prepare_sort_table CHANGING pt_sort TYPE lvc_t_sort .DATA ls_sort TYPE lvc_s_sort .ls_sort-spos = '1' .ls_sort-fieldname = 'CARRID' .ls_sort-up = 'X' . "A to Zls_sort-down = space .APPEND ls_sort TO pt_sort .ls_sort-spos = '2' .ls_sort-fieldname = 'SEATSOCC' .ls_sort-up = space .ls_sort-down = 'X' . "Z to AAPPEND ls_sort TO pt_sort .ENDFORM. " prepare_sort_table这有2点特别的说明:1.如果这边排序的字段名,不存在于字段目录中,那将出现DUMP.2.排序以后,垂直的网格中,如果出现相同的内容,就会合并,如果要避免,请在布局中设置"no_merging"为"X" .你可以通过使用方法“get_sort_criteria” 和“set_sort_criteria”来获取和设置排序的标准.功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FILT"创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法"SET_TABLE_FOR_FIRST_DISPLAY"中的参数"IT_FILTER"FORM prepare_filter_table CHANGING pt_filt TYPE lvc_t_filt .DATA ls_filt TYPE lvc_s_filt .ls_filt-fieldname = 'FLDATE' .ls_filt-sign = 'E' .ls_filt-option = 'BT' .ls_filt-low = '20030101' .ls_filt-high = '20031231' .APPEND ls_filt TO pt_filt .ENDFORM. " preparefiltertable我们可以使用"get_filter_criteria" 和"set_filter_criteria"来获取过滤条件和设置过滤条件.功能四:选择方式有时候,我们需要选择一些单元格,行或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择方式的设置的.2.设置了选择方式以后,我们可以使用很多方法来获取用户的选择.比如"GET_SELECTED_CELLS","GET_SELECTED_CELLS_ID","GET_SELECTED_R OWS","GET_SELECTED_COLUMNS"3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PBO中,使用对应的SET方法来恢复这些选择.功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cx y z---Color | | || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第一位,第二位代表是颜色编码(1到7),第三位是加强的设置,第四位是相反,个人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:A)设置列的颜色.我们可以通过字段目录的"emphasize"控制字段来控制某列的颜色.这个字段同样是4位的CHAR型,传入上述的颜色编码.例如:LS_FCAT-EMPHASIZE = 'C701'.如果这列被设置为关键列,就是 LS_FCAT-KEY = 'X' ,那么颜色设置就不会起作用.请注意,自动产生的字段目录中,KEY的设置是自动获取的.B)设置行的颜色为某行设置颜色,是有点复杂的,我们需要在要显示的数据内表中增加一个字段,这个字段不需要在字段目录中存在.同样,这个字段也是4位的CHAR型,符合颜色编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA END OF gt_list .很明显,填入颜色编码以后,ALV怎么知道它是我们用来设置颜色的呢,在布局中,有个控制字段"INFO_FNAME",我们可以设置这个字段来告诉ALV,我们的颜色字段是哪个.ps_layout-info_fname = 'ROWCOLOR'.请注意,这个字段随便你起名字,但是记住,一定是数据内表里的字段,而且这边设置的时候一定要大写.你可以在任何时候设置行的颜色,只需要去修改内表里的这个字段的值,但是记得,一定要刷新以后才起作用.C)设置单元格的颜色设置单元格和设置行的颜色,本质上没有什么大的区别,但是定位单元格需要2个参数.我们需要在数据内表中插入一个表类型的字段,这样我们的数据内表就变成了DEEP结构了,不过ALV是可以处理的.不需要担心.插入的这个表类型的类型为"LVC_T_SCOL".里面有3个参数:FNAME告诉我们你需要设置的是哪个字段,如果为空,然后直接在COLOR中设置颜色,就是整行设置为这个颜色.如果具体到某个单元格,必须指定是哪个字段.COLOR字段是用来设置颜色的.NOKEYCOL字段比较关键了.设置为关键列的一些字段,我们的颜色设置可能被覆盖.通过这个字段的设置,可以避免被关键列覆盖.同样,ALV在布局中有个字段"CTAB_FNAME"告诉我们,数据内表中,哪个字段是用来设置单元格的颜色的.DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA END OF gt_list .DATA ls_cellcolor TYPE lvc_s_scol ....READ TABLE gt_list INDEX 5 .ls_cellcolor-fname = 'SEATSOCC' .ls_cellcolor-color-col = '7' .ls_cellcolor-color-int = '1' .APPEND ls_cellcolor TO gt_list-cellcolors .MODIFY gt_list INDEX 5 .注意:颜色设置中有优先级顺序,他们是单元格--->行--->列.功能六:插入超链接插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为"LVC_T_HYPE" ,句柄是一个INT4类型的字段,我们需要在数据显示的内表中,加入这样的字段,来告诉ALV,我们的字段指定的句柄,从而找到对应的超级链接.在字段目录中,WEB_FIELD是用来指定对应的句柄名的.下面举个例子来说明,我们要为字段CARRID,CONNID建立超级链接:首先,内表定义中,我们加入2个句柄字段:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA carrid_handle TYPE int4 .DATA connid_handle TYPE int4 .DATA END OF gt_list .第二: 建立一个超级链接内表,里面存放句柄所对应的超级链接.创建的时候注意,它参考的表类型,一定是"LVC_T_HYPE".FORM prepare_hyperlinks_table CHANGING pt_hype TYPE lvc_t_hype .DATA ls_hype TYPE lvc_s_hype .ls_hype-handle = '1' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '2' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '3' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '4' .ls_hype-href = '/connids/con11' .APPEND ls_hype TO pt_hype .ls_hype-handle = '5' .ls_hype-href = '/connids/con12'APPEND ls_hype TO pt_hype ... ..ENDFORM .第三.通过字段目录FIELDCATLOG来指定相应的句柄字段.对于CARRID的field catalogLs_fieldcat-web_field = …CARRID_HANDLE‟.对于CONNID的field catalogLs_fieldcat-web_field = …CONNID_HANDLE‟.在方法"SET_TABLE_FOR_FIRST_DISPLAY"中把句柄内表传给参数it_hyperlink。

abap alv字段 值描述 -回复

abap alv字段 值描述 -回复

abap alv字段值描述-回复ABAP是一种面向对象的编程语言,用于SAP系统的开发。

在ABAP中,ALV是模块化的列表显示工具,用于在SAP系统中显示表格格式的数据。

ALV的字段描述用于提供用户对显示的数据进行解释和理解的信息。

本文将详细介绍ABAP ALV字段值描述的概念、作用、实现方法以及在SAP 系统中的应用。

首先,我们来了解一下ABAP ALV字段值描述的概念。

在ALV表格中,每个列都有一个字段描述,该描述用于提供关于该列的详细信息,包括该列表示的含义、数据类型、取值范围等。

字段值描述是字段描述的补充,用于解释字段的具体取值。

例如,在一个销售订单的ALV表格中,有一列是"订单状态",可能取值为"未处理"、"进行中"和"已完成",字段值描述可以为每个具体的取值提供详细的说明,比如"未处理:订单尚未被处理"、"进行中:订单正在进行中"和"已完成:订单已经完成"。

接下来,我们来探讨一下ABAP ALV字段值描述的作用。

字段值描述可以在ALV表格中提供更加友好和易于理解的数据展示,帮助用户更加准确地理解表格中数据的含义。

对于那些有特定业务规则和含义的字段,字段值描述可以起到解释和澄清的作用,减少用户对数据的困惑和误解。

此外,通过字段值描述,用户还可以直观地了解每个字段值的含义,从而更好地进行数据分析和决策。

那么,我们该如何在ABAP中实现ALV字段值描述呢?ABAP提供了一些特定的函数和方法来实现这个功能。

首先,我们需要在数据字典中为每个字段值创建描述,可以使用数据元素或者域来做到这一点。

然后,在程序中,使用函数模块"REUSE_ALV_COMMENTARY_WRITE"将描述信息和字段值关联起来,并将其显示在ALV表格中的相应列中。

函数alv

函数alv

函数alvalv 函数是一个编程中常用的函数,它可以实现各种功能,包括数学计算、字符串操作以及数组处理等等。

本篇文章主要介绍alv函数的使用及其相关内容。

一、函数alv的基本介绍在编程中,alv函数是语言中的一个函数,可以理解为某个子程序或功能模块。

它通常包含有输入和输出两个部分,可以接受相关参数进行运算和处理,返回相应的结果。

在其他程序中调用alv函数可以充分利用已经实现好的代码模块,提高开发效率。

二、alv函数的常用操作常用的alv函数包括数学函数、字符串函数、日期与时间函数以及数组函数等。

1.数学函数:alv函数的数学计算功能包括各种常见数学运算,如加减乘除、取绝对值、幂函数、求余数、求最大最小值、取整数等等。

数学函数在数值计算、统计分析等领域应用广泛。

例如,alv函数可以通过以下方式实现求和运算:data: r(3) type i value 3.call function 'ALV_HIERARCHY_SUM'exportingi_mode = 1it_table = ri_fieldname = 'FIELD'importinge_value = sum.2.字符串函数:alv函数的字符串操作功能包括字符串连接、分隔、截取、查找替换等。

字符串函数在文本处理、数据清洗等领域应用广泛。

3.日期与时间函数:alv函数的日期与时间操作功能包括日期时间格式化、计算与比较、日期时间转换等。

日期时间函数在时间戳处理、时区转换、日历计算等领域应用广泛。

由于alv函数是经过封装的代码模块,其具有高通用性、可重复使用、易维护等优势。

1.高通用性。

alv函数可以适用于不同编程语言和不同平台,使得代码的移植和集成更加便捷。

2.可重复使用。

开发者只需按需调用alv函数,无需每次重复编写相同的功能代码,从而提高开发效率和可维护性。

3.易维护。

alv函数的封装使得代码更加清晰、简洁,易于维护,有助于减少代码出错概率,提高代码可读性。

ALV 介绍(CALL FUCTION)

ALV 介绍(CALL FUCTION)

ALV Simple Introduction一、ALV相关概念ALV――ALV = SAP List Viewer,这里我们姑且称之为ABAP表单浏览器,用它可以标准化,简单化R/3系统中的表单,它可以提供给用户一个统一的表单格式以及用户接口。

二、结合一个具体的实例来看ALV的功能首先我们看下图中的这个ALV的布局(这是一般ALV程序表单的典型布局):根据上面对ALV的直观形象,下面将屏幕上的区域划分成几块,分别来解释它的作用:1.快捷工具栏(如下图)细节按钮,你首先必须选中列表中的一行,然后点击它的话,就会弹出一个窗口,显示选中行的细节内容。

(另外:你双击你要选择的行,也可以显示细节)按升序排列,首先选中一列,然后再点击它,就可以看到该列是按照升序重新排列。

按降序排列,首先选中一列,然后再点击它,就可以看到该列是按照降序重新排列。

设置过滤器,通过设置它可以达到筛选的目的,以列名称作为筛选的筛选标准,填入过滤器相应的标准值,然后就可以筛选出满足自己条件的记录。

打印预览,点击它之后,就可以预览一下将要打印内容的布局情况。

Microsoft Excel,调用MS的Excel到当前ALV的列表显示区域。

(前提:必须安装了MS的Excel)字处理,字处理的相关设置。

本地文件,将当前表单存储到本地机器上,有几种供选择的存储格式。

邮件收件人,给系统内用户发邮件图形,点击它可以根据表单情况绘制相关图表。

更改布局,点击它可以对表单中的列项目排列次序的互换,删减等。

选择布局,从已经保存的布局中选择自己满意的布局。

保存布局,对于自己满意的布局,可以通过点击它来将布局保存起来。

2.表单标题区这个区域主要是用来显示一些抬头信息(总揽信息),类似于WORD中的页眉。

我们在使用的时候根据需要来进行相关填写。

3.表单显示区这个区域主要是用来显示我们通过代码筛选出来的数据,相关的操作在下面的程序编写部分详细介绍。

三、程序的编写1.写一个ALV程序的基本流程:第一步:定义将要用到的表,即TALBES定义部分,然后定义TYPE-POOLS: SLIS.第二步:定义第一步中提到的这些数据类型或者内表的实体对象第三步:定义一些需要用到的变量第四步:定义自己的选择屏幕第五步:start-of-selection部分○1用一个子函数完成自己所需要数据的抓取○2用一个子函数完成要显示列表的列名行(第一行)的相关赋值(i_fieldcat_alv)以及设置○3用一个子函数完成输出格式的设置(i_layout),比如双击一条记录是否弹出对话框啊?是用哪个功能键触发等等○4用一个子函数FORM DISPLAY_DATA来显示上面我们已经分别封装好的数据,需要调用两个常用的FUNCTION MODULE:FUNCTION 'REUSE_ALV_GRID_DISPLAY' “用来显示表单数据FUNCTION 'REUSE_ALV_COMMENTARY_WRITE' “用来显示表单标题2.在我们写ALV程序的时候,有一个类型组是肯定要用到的:TYPE-POOLS:SLIS。

SAP_ALV_详细使用方法

SAP_ALV_详细使用方法

ALV学习资料SAP提供一组ALV(ABAP LIST VIEWER)功能模块,这些功能模块可以修饰报表输出。

这些设置的ALV功能可以提高报表的可读性。

首先呢,我先跟大家说一下ALV是什么东西?ALV=SAP LIST VIEWER,SAP列表显示器。

就目前ALV技术主要分ALV GRID 和ALV TREE。

先跟大家说一下目前本人用的比较多的ALV GRID技术,ALV GRID 的效果见图(1.1)。

图(1.1)第一步在使用ALV时,需要定义一个SAP标准TYPE-POOLS,具体语法为:TYPE-POOLS: SLIS.然后需要定义一个LAYOUT式样,和一个FIELDCAT字段格式,具体语法为:DATA: LIT_FCAT TYPE SLIS_T_FIELDCAT_ALV,LT_LAYO TYPE SLIS_LAYOUT_ALV,GIT_EVENTS TYPE SLIS_T_EVENT,GIT_LISTHEADER TYPE SLIS_T_LISTHEADER.,LIT_EXTAB TYPE SLIS_T_EXTAB.第二步(可选)可以为需要为最初的目录显示选择参数。

在这里需要使用函数‘'REUSE_ALV_V ARIANT_DEFAULT_GET’Sample code:CALL FUNCTION 'REUSE_ALV_V ARIANT_DEFAULT_GET'EXPORTINGi_save = variant save condition ( A=all, U = user-specific )CHANGINGcs_variant = internal table containing the program name (and the defaultvariant---optional )EXCEPTIONSnot_found = 2.使用者也可以使用现有的变量中选择,使用函数‘REUSE_ALV_V ARIANT_F4’。

abap-ALV-功能

abap-ALV-功能

ALV Simple Introduction一、ALV相关概念ALV――ABAP LIST VIEWER,这里我们姑且称之为ABAP表单浏览器,用它可以标准化,简单化R/3系统中的表单,它可以提供给用户一个统一的表单格式以及用户接口。

二、结合一个具体的实例来看ALV的功能首先我们看下图中的这个ALV的布局(这是一般ALV程序表单的典型布局):根据上面对ALV的直观形象,下面将屏幕上的区域划分成几块,分别来解释它的作用:1.快捷工具栏(如下图)细节按钮,你首先必须选中列表中的一行,然后点击它的话,就会弹出一个窗口,显示选中行的细节内容。

(另外:你双击你要选择的行,也可以显示细节)按升序排列,首先选中一列,然后再点击它,就可以看到该列是按照升序重新排列。

按降序排列,首先选中一列,然后再点击它,就可以看到该列是按照降序重新排列。

设置过滤器,通过设置它可以达到筛选的目的,以列名称作为筛选的筛选标准,填入过滤器相应的标准值,然后就可以筛选出满足自己条件的记录。

打印预览,点击它之后,就可以预览一下将要打印内容的布局情况。

Microsoft Excel,调用MS的Excel到当前ALV的列表显示区域。

(前提:必须安装了MS的Excel)字处理,字处理的相关设置。

本地文件,将当前表单存储到本地机器上,有几种供选择的存储格式。

邮件收件人,给系统内用户发邮件图形,点击它可以根据表单情况绘制相关图表。

更改布局,点击它可以对表单中的列项目排列次序的互换,删减等。

选择布局,从已经保存的布局中选择自己满意的布局。

保存布局,对于自己满意的布局,可以通过点击它来将布局保存起来。

2.表单标题区这个区域主要是用来显示一些抬头信息(总揽信息),类似于WORD中的页眉。

我们在使用的时候根据需要来进行相关填写。

3.表单显示区这个区域主要是用来显示我们通过代码筛选出来的数据,相关的操作在下面的程序编写部分详细介绍。

三、程序的编写1.写一个ALV程序的基本流程:第一步:定义将要用到的表,即TALBES定义部分,然后定义TYPE-POOLS: SLIS.。

SAP_ALV_详细使用方法

SAP_ALV_详细使用方法

ALV学习资料SAP提供一组ALV(ABAP LIST VIEWER)功能模块,这些功能模块可以修饰报表输出。

这些设置的ALV功能可以提高报表的可读性。

首先呢,我先跟大家说一下ALV是什么东西?ALV=SAP LIST VIEWER,SAP列表显示器。

就目前ALV技术主要分ALV GRID 和ALV TREE。

先跟大家说一下目前本人用的比较多的ALV GRID技术,ALV GRID 的效果见图(1.1)。

图(1.1)第一步在使用ALV时,需要定义一个SAP标准TYPE-POOLS,具体语法为:TYPE-POOLS: SLIS.然后需要定义一个LAYOUT式样,和一个FIELDCAT字段格式,具体语法为:DATA: LIT_FCAT TYPE SLIS_T_FIELDCAT_ALV,LT_LAYO TYPE SLIS_LAYOUT_ALV,GIT_EVENTS TYPE SLIS_T_EVENT,GIT_LISTHEADER TYPE SLIS_T_LISTHEADER.,LIT_EXTAB TYPE SLIS_T_EXTAB.第二步(可选)可以为需要为最初的目录显示选择参数。

在这里需要使用函数‘'REUSE_ALV_V ARIANT_DEFAULT_GET’Sample code:CALL FUNCTION 'REUSE_ALV_V ARIANT_DEFAULT_GET'EXPORTINGi_save = variant save condition ( A=all, U = user-specific )CHANGINGcs_variant = internal table containing the program name (and the defaultvariant---optional )EXCEPTIONSnot_found = 2.使用者也可以使用现有的变量中选择,使用函数‘REUSE_ALV_V ARIANT_F4’。

alv标准功能编号

alv标准功能编号

alv标准功能编号ALV(Advanced List View)是SAP提供的一个报表程序,用于生成一个交互式的、灵活的报表。

功能编号是指对ALV中各个功能的标识和引用。

在SAP的ALV中,标准功能编号包括:1. ALV_DELETE_FILTER:删除过滤器。

2. ALV_INSERT_FILTER:插入过滤器。

3. ALV_SCREEN_SIZE:设置屏幕大小。

4. ALV_SET_SORTING:设置排序。

5. ALV_RESET:重置ALV。

6. ALV_COMMIT:提交ALV更改。

7. ALV_GET_FILTER:获取过滤器值。

8. ALV_SET_FILTER:设置过滤器值。

9. ALV_GET_SORTING:获取排序设置。

10. ALV_SET_SORTING:设置排序设置。

11. ALV_GET_SCREEN_SIZE:获取屏幕大小。

12. ALV_SET_SCREEN_SIZE:设置屏幕大小。

13. ALV_GET_DATA:获取ALV数据。

14. ALV_SET_DATA:设置ALV数据。

15. ALV_GET_DISPLAY:获取ALV显示设置。

16. ALV_SET_DISPLAY:设置ALV显示设置。

17. ALV_GET_OPTIONS:获取ALV选项设置。

18. ALV_SET_OPTIONS:设置ALV选项设置。

19. ALV_GET_DATA_FOR_GRAPH:获取用于图表的数据。

20. ALV_SET_DATA_FOR_GRAPH:设置用于图表的数据。

21. ALV_GET_GROUPING:获取分组设置。

22. ALV_SET_GROUPING:设置分组设置。

23. ALV_GET_DRILLDOWN:获取钻取设置。

24. ALV_SET_DRILLDOWN:设置钻取设置。

25. ALV_GET_PDCA:获取PDCA设置。

26. ALV_SET_PDCA:设置PDCA设置。

ALV-讲解

ALV-讲解

ALV讲解一、ALV简介ALV――SAP LIST VIEWER是SAP中的一种报表方式,这里姑且称之为ABAP 表单浏览器,用它可以标准化,简单化R/3系统中的表单,它可以提供给用户一个统一的表单格式及用户接口。

ALV是系统的一种网格的显示方式,这种方式带有汇总\排序\筛选等功能,ALV格式的数据是以单元格为单位显示,SAP提供了一套ALV的功能模块,可以对输出报表的样式作修饰,提高报表输出的可读性和功能性,对于动态报表程序是一个很有效率的工具。

ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV。

一般的ALV报表有一个表头,再加上表内容,并附加一些如排序,分类汇总,合计或下载为本地文件等预设功能。

ALV用到的函数:REUSE_ALV_GRID_DISPLAY、REUSE_ALV_GRID_DISPLAY_LVC;两个函数都可以将数据用ALV的形式显示出来,只是在一些小的地方有些不同。

二、两个function全局变量的定义(1)“用来显示表单数据FUNCTION 'REUSE_ALV_GRID_DISPLAY' 全局变量如下:DATA: wa_fieldcat TYPE slis_fieldcat_alv , "相当于工作区i_fieldcat TYPE slis_t_fieldcat_alv , "存放列名的内表i_layout TYPE slis_layout_alv . "负责整个ALV的全局属性(2)“用来显示表单数据FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC ' 全局变量如下:DATA: wa_fieldcat TYPE lvc_s_fcat , "相当于工作区i_fieldcat TYPE lvc_t_fcat , "存放列名的内表i_layout TYPE lvc_s_layo . "负责整个ALV的全局属性三、ALV技术要点简介下面以函数(REUSE_ALV_GRID_DISPLAY_LVC)为例,来介绍ALV的用法。

alv入门

alv入门

ABAP筑基宝典(9)——ALV报表入门一 .什么是ALVSAP提供一套ALV(Application List viewer.)的功能模块,可以对输出报表的样式作修饰,提高报表输出的可读性和功能性,对于动态报表程序是一个很有效率的工具。

一般的ALV报表有一个表头,再加上表内容,并附加一些如排序,分类汇总,合计或下载为本地文件等预设功能。

ALV报表显示方式基本上有2种,一种是Grid方式,一种是 List方式,分别调用不同的Function来实现。

二.ALV式样1. REUSE_ALV_GRID_DISPLAY2. REUSE_ALV_LIST_DISPLAY3.ALV工具栏三.ALV函数的调用当完成从数据库抽取数据或上传数据,并将数据存放到内部表(IT_ABC)后,开始调用下面的ALV函数模块。

1.指定数据类型组TYPE-POOLS: SLIS.DATA:IT_FIELDCAT TYPE SLIS_T_FIELDCAT_ALV, "ALV输出项目编辑用WA_FIELDCAT TYPE SLIS_FIELDCAT_ALV, "ALV输出项目编辑用WA_LAYOUT TYPE SLIS_LAYOUT_ALV. "ALV样式设定用2.调出函数模块CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'EXPORTINGIS_LAYOUT = WA_LAYOUTIT_FIELDCAT = IT_FIELDCATTABLEST_OUTTAB = IT_TAB.......3. 函数的各项说明CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'EXPORTINGI_STRUCTURE_NAME = 已经存在SAP系统中的结构IS_LAYOUT = 布局IT_FIELDCAT = 自定义IT_SORT = 对项目的一个排序IT_EVENTS = 标题部分......四.使用ALV的注意事项1.在ALV中,需要注意所有添加的需要显示的列,都必须在相应的内表中有对应的字段,否则,只要使用合计或者分类汇总都会导致程序的崩溃。

ALV详细字段介绍以及一些用法

ALV详细字段介绍以及一些用法

ALV详细字段介绍ALV常用参数的详细描述调用功能模块:CALL FUNCTION \'REUS E_ALV_GRID_DIS PLAY\'EXPOR TINGi_interface_check = \'\' 接口一致性检查i_callback_program = sy-repid 当前程序名is_layout = layout 输出样式it_f ieldcat = 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[] 排序设置TABLESt_outtab = ig_outEX CEPTIONSprogram_error = 1OTHERS = 2.常用属性:(赋值‟‟中内容必须为大写)1. Fieldcatdata: fieldcat type slis_t_fieldcat_alv w ith header line.it_fieldcat = fieldcat[]属性(用来定义表单中的各个列的相关信息)Fieldcat-col_pos = n. 输出列Fieldcat-tabname = …FIELDNAME‟.对应的内表字段名Fieldcat-seltext_s/m/l = …列名‟. 输出列文本(_s:短文本 _l:长文本)Fieldcat-emphasize = …CX10‟.带有颜色的高亮列(其中X=(1-7)颜色同f ormat) Fieldcat-hotspot = …X‟.作为热点显示,可触发鼠标触发事件Fieldcat-c urrency = …CURRKEY‟.表 TCURX 中的货币名称 Fieldcat-quantity(3) 计量单位Fieldcat-qfieldname = '数量' 参考计量单位的字段名称 Fieldcat-round = n. 四舍五入至小数位数下n 位Fieldcat-exponent = n. 浮点数的幂指数为nFieldcat-key = …X‟.关键字段Fieldcat-icon = …X‟.作为图标输出Fieldcat-symbol = …X‟.输出作为符号Fieldcat-checkbox = …X‟.作为复选框输出Fieldcat-j ust = SPACE, \'R\', \'L\', \'C\'. 对齐方式Fieldcat-lzero = …X‟.输出前导零Fieldcat-no_sign = …X‟.输出抑制符号Fieldcat-no_zero = …X‟.为输出隐藏零Fieldcat-edit_mask = SPACE, mask.输出为mask的模式 Fieldcat-f ix_column = …X‟.固定列Fieldcat-do_sum = …X‟.总计列值总和Fieldcat-no_out = …X‟.列不输出Fieldcat-tech = …X‟.该字段为技术字段Fieldcat-outputlen = n 列的字符宽度为nFieldcat-decimals_out = n 能控制小数点的位数为nFieldcat-datatype = C,I,N…定义数据类型2. SORTdata: sortable type slis_t_sortinfo_alv with header line.it_sort = sortable[]属性(排序)Sortable-Fieldname 字段名U p 升序排列Dow n 降序排列Subtot3. Layoutdata: layout type slis_layout_alv .is_layout = layout属性 (用于定义ALV表单的相关格式、属性)inf o_f ieldname = 'LINE_COLOR'. 设置特殊行颜色(将LINE_COLOR增加到内表字段,写'CX10'到特殊行的LINE_COLOR, X为颜色值)colwidth_optimize = …X‟.优化列宽设置no_colhead = 'X'. 不显示列名no_vline = 'X'. 不显示列间竖线zebra = 'X' 可选行颜色,如果设置了,出现了间隔色带f2code = '&ETA'. 设置触发弹出详细信息窗口的功能码,这里是双击detail_initial_linesdetail_popup 是否弹出详细信息窗口detail_titlebar 设置弹出窗口的标题栏totals_texttotals_onlygroup_change_editheader_text4.按钮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'出口程序触发事件对应子程序:FOR M PF_STATUS_SET USING rt_extab TYPE slis_t_extab.FOR M user_command USING ucomm LIKE sy-ucomm self ield TYPE slis_self ield. 功能代码: 函数文本: 图标名称:&ETA 细节 ICON_SELECT_DETAIL&EB9 调用报告... ICON_TABLE_SETTINGS&REFRESH 刷新 ICON_REFR ESH&ALL 全部选择 ICON_SELECT_ALL&SAL 取消全选 ICON_DES ELECT_ALL&OUP 按升序排列 ICON_SOR T_UP&ODN 按降序排列 ICON_S ORT_DOWN&ILT 设置过滤器 ICON_FILTER&UMC 总计 ICON_SUM&SUM 小计... ICON_INTER MEDIATE_S UM&RNT_PR EV 打印预览 ICON_LAYOUT_CONTR OL&VEX CEL M icrosof t Excel ICON_XLS&AQW 字处理... ICON_W ORD_PR OCESSING%PC 本地文件 ... ICON_EXPORT%SL 邮件收件人 ICON_MAIL&AB C ABC分析 ICON_AB C&GRAPH 图形 ICON_GR APHICS&OL0更改布局... ICON_ALV_VAR IANTS&OAD 选择格式... ICON_ALV_VAR IANT_CHOOS E&AVE 保存格式... ICON_ALV_VAR IANT_S AVE&INF O 信息 ICON_INF OR MATION1. ALV表头设置i_callback_html_top_of_page = 'ALV_TOP_OF_PAGE'form top_of_page using cl_dd type ref to cl_dd_document.语法同HTML fomatALV_GRID介绍一.ALV介绍The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用.SAP提示: 在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具,然而,目前这个功能只在实验计划中使用,还没有向客户发布.下面是一个ALV GRID的图片:它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏.ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV.二.ALV GRID CONTR OL (ALV网格控制器)ALV GRID CONTR OL使用了控制器技术以实现艺术性的屏幕显示,象所有的控制器一样,ALV GRID CONTR OL通过系统中的一个全局的类提供了方法,以响应它的动作.使用了AB AP的对象以后,列表是通过ALV的一个实例(INS TANCE)来显示的,程序员可以使用AB AP对象的事件管理.三.ALV GRID CONTR OL 实例ALV GRID实例的定义,参照CL_GUI_ALV_GRID类data ALV_GRID1 type ref to cl_gui_alv_grid.ALV GRID继承结构:ALV_GRID介绍(1)四、ALV GRID相关的几个控制结构1.字段目录 [Field catalog]字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTUR E LVC_S_FCAT)2R OW_POS ALV控制: 输出行 (内部使用)3COL_POS ALV 控制: 输出列列的位置,第几列,例如1,2,…..4FIELDNAME ALV 控制: 内部表字段的字段名称字段名称5TAB NAME LVC 标签名称表名,如果是内表,是16CURRENCY ALV 控制: 货币单位7CF IELDNAME ALV控制: 参考的当前单位的字段名称8QUANTITY ALV 控制: 计量单位9QFIELDNAME ALV 控制: 参考计量单位的字段名称10 IFIELDNAME ALV控制: 内部表字段的字段名称11 ROUND ALV控制: ROUND 值12 EXPONENT ALV 控制:流动表示的指数13 KEY ALV 控制: 关键字段关键字段,前面变蓝色14 KEY_SEL ALV控制: 可以被隐藏的关键列可以被隐藏的关键列15 ICON ALV 控制: 作为图标输出此列作为图标输出16 SYMB OL ALV 控制: 输出作为符号17 CHECKB OX ALV 控制: 作为复选框输出复选框输出18 JUST ALV控制: 对齐对齐方式:\'R\': right j ustif ied\'L\': lef t justified\'C\': centered19 LZER O ALV 控制: 输出前导零 X\'20 NO_SIGN ALV控制:输出抑制符号 X\',不输出符号21 NO_ZER O ALV 控制: 为输出隐藏零 X\',隐藏022 NO_CONVEX T ALV 控制: 不考虑输出的转换退出23 EDIT_MASK ALV 控制: 为输出编辑掩码格式24 EMPHASIZE ALV控制: 带有颜色的高亮列列的颜色25 FIX_COLUMN ALV 控制: 固定列26 DO_S UM ALV控制: 总计列值 X\',合计27 NO_SUM ALV控制: 没有总计列值 X\' ,没有合计28 NO_OUT ALV 控制: 列没有输出 X\' ,隐藏此列29 TECH ALV控制: 技术字段 X\'.也是隐藏,但是有点不一样30 OUTPUTLEN ALV 控制: 列的字符宽度输出的长度31 CONVEX IT 转换例程32 SELTEX T ALV 控制: 对话功能的列标识符33 TOOLTIP ALV 控制: 列抬头的工具提示34 ROLLNAME ALV 控制: F1帮助的数据元素35 DATATYPE AB AP字典中的数据类型 AB AP字典中的数据类型36 INTTYPE AB AP 数据类型(C,D,N,...) AB AP 数据类型(C,D,N,...)37 INTLEN以字节计的内部长度内容的长度38 LOWER CAS E允许/不允许小写字母 X\' 允许大小写39 REPTEX T 标题40 HIER_LEVEL ALV 控制: 内部使用41 REPR EP ALV控制: 价值是补充/补充接口的选择标准42 DOMNAME 定义域名43 SP_GR OUP 组代码44 HOTS POT ALV 控制: 单击敏感 X\',下面出现下划线,响应单击45 DFIELDNAME ALV控制: 数据库中列组的字段名称46 COL_ID ALV控制: 列 ID47 F4AVAILABL 字段有输入帮助吗 X\'.此列有搜索帮助48 AUTO_VALUE ALV控制: 自动复制值49 CHECKTABLE 表名50 VALEXI 固定值存在51 WEB_FIELD ALV 控制: 内部表字段的字段名称52 HREF_HNDL 自然数热点连接的句柄53 STYLE ALV 控制: 样式下面有例子会介绍,比如PUS HBUTTION54 STYLE2 ALV控制: 样式55 STYLE3 ALV控制: 样式56 STYLE4 ALV控制: 样式57 DRDN_HNDL 自然数下拉的句柄58 DRDN_FIELD ALV 控制: 内部表字段的字段名称下拉的字段59 NO_MER GING 字符字段长度 1相同的值不合并60 H_FTYPE ALV树控制: 功能类型 (总计,平均,最大.最小, ...)61 COL_OPT 可选列优化的条目62 NO_INIT_CH 字符字段长度 163 DRDN_ALIAS 字符字段长度 164 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 COLTEX T ALV 控制: 列标题列标题73 SCR TEX T_L 长字段标签74 SCR TEX T_M 中字段标签75 SCR TEX T_S 短字段标签76 COLDDICTX T ALV控制: 确定 DDIC 文本参考77 SELDDICTX T ALV 控制: 确定 DDIC文本参考78 TIPDDICTX T ALV 控制: 确定 DDIC文本参考79 EDIT ALV 控制: 准备输入输出状态.\'X\'可输入80 TECH_COL ALV控制: 内部使用81 TECH_FOR M ALV 控制: 内部使用82 TECH_COMP ALV 控制: 内部使用83 HIER_CPOS ALV 控制: 层次列位置84 H_COL_KEY 树控制: 列名称/项目名称85 H_SELECT标识是否可以选择树控制中的列86 DD_ROLL 数据元素 (语义域)87 DRAGDR OPID ALV控制: 拖&放处理拖放对象88 MAC字符字段长度 189 INDX_FIELD 自然数90 INDX_CFIEL 自然数91 INDX_QFIEL 自然数92 INDX_IFIEL 自然数93 INDX_R OUND 自然数94 INDX_DECML 自然数95 GET_S TYLE 字符字段长度 196 MARK 字符字段长度 1ALV_GRID介绍(2)2.布局控制[layout]布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.参照ALV的控制结构[LVC_S_LAYO],以后的例子我将详细介绍如何设置行颜色和列颜色. 详细的结构说明字段名描述 Value rangeCWIDTH_OPT 最优化宽度 SPACE, \'X\'SMALLTITLE小标题,如果设置了这个字段,则标题与列标题大小一样 SPACE, \'X\' GRID_TITLE标题,在网格和工具条之间最长70个字符NO_HEADERS 如果被设置,列标题隐藏 SPACE, \'X\'NO_HGRIDLN 隐藏水平线 SPACE, \'X\'NO_MER GING 禁用单元格合并 SPACE, \'X\'NO_ROWMARK 如果被设置,选择列在选择模式,为D和A的时候隐藏 SPACE, \'X\' NO_TOOLB AR 隐藏工具条 SPACE, \'X\'NO_VGRIDLN 隐藏垂直线 SPACE, \'X\'SEL_MODE 选择模式 SPACE, \'A\', \'B\', \'C\', \'D\'EX CP_CONDS 合计例外 SPACE, \'X\'EX CP_FNAME字段名称带有例外编码最长30个字符EX CP_LED 例外作为 LED SPACE, \'X\'EX CP_R OLLN例外文档的数据元素 SPACE, \'X\'CTAB_FNAME 带有复杂单元格颜色编码的字段名称最长30个字符INF O_FNAME 带有简单行彩色代码的字段名称最长30个字符ZEBR A 可选行颜色,如果设置了,出现了间隔色带 SPACE, \'X\'NO_TOTLINE 没有总计 SPACE, \'X\'NUMC_TOTAL 可以对NUMC字段进行合计 SPACE, \'X\'TOTALS_BEF 总计输出在第一行,小计在新的值之前 SPACE, \'X\'STYLEF NAME 设置单元格,比如PUS HBUTTON 最长30个字符ALV_GRID介绍(3)3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SOR T]过滤的参数控制请参考结构[LVC_S_FILT]这里不再一一解释,进入中文版本,里面应该也有解释的,虽然一些不是很清楚.五.编写简单的ALV程序.首先这里就不详细介绍DIALOG的用法了.OO的ALV GRID必须存在于一个容器当中,就是FUNCTION的ALV,其实也是一样的,底层也是使用CL_GUI_ALV_GR ID这个类的.首先ALV的显示需要有几个先决条件.1,字段目录,这个是必须的,如果没有这个参数,参考一个数据字典也是可以的,就是参数I_STR UCTUR E_NAME.2.存放数据的内表,最好内表的结构和字段目录是一致的,否则可能会出现一些无法预知的错误,当然你说我非要不一样,那也不一定会出现错误.我建议是最好一样的.这2个是必须的,布局的话,应该是可以不设置的,使用默认的就可以了.第一步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量.DATA:WCL_CONTAINER TYPE REF TO CL_GUI_CUS TOM_CONTAINER,WCL_ALV TYPE REF TO CL_GUI_ALV_GRID .*--- 存放字段目录的内表DATA gt_f ieldcat TYPE lvc_t_f cat .*--- 布局结构DATA gs_layout TYPE lvc_s_layo .*----声明需要显示的内表(以SFLIGHT为例)DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTUR E SFLIGHT .DATA END OF gt_list .第二步: 创建ALV这个对象,它的父组件是那个容器.在PBO中写入如下代码:PROCESS BEF ORE OUTPUT .创建DISPLAY_ALV的MODULE后,写下如下代码:MODULE display_alv OUTPUT .PERF OR M display_alv .ENDMODULE .在FOR M DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建: IF WCL_ALV IS INITIAL .CREATE OBJ ECT: WCL_CONTAINEREXPOR TINGCONTAINER_NAME = \'ALV_CON\'.CREATE OBJ ECT WCL_ALVEXPORTINGI_PARENT = WCL_CONTAINER."准备获取字段目录PERF OR M prepare_f ield_catalog CHANGING gt_f ieldcat ."设置布局PERF OR M prepare_layout CHANGING gs_layout ."显示ALVCALL METHOD gr_alvgrid->set_table_for_f irst_displayEXPOR TING* I_BUFFER_ACTIVE =* I_CONS IS TENCY_CHECK =* I_STRUCTUR E_NAME =* IS_VARIANT =* I_SAVE =* I_DEF AULT = \'X\'* IS_PRINT =* IT_SPECIAL_GR OUPS =* IT_TOOLB AR_EX CLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_list[]it_f ieldcatalog = gt_fieldcat* IT_S ORT =* IT_FILTER =EXCEPTIONSinvalid_parameter_combination = 1program_error = 2too_many_lines = 3OTHERS = 4 .ELSE.*----刷新ALVCALL METHOD gr_alvgrid->ref res h_table_display * EXPORTING* IS_STABLE =* I_SOF T_REFRES H =EXCEPTIONSfinished = 1OTHERS = 2 .IF sy-subrc <> 0.*--异常处理ENDIF.ENDIF .方法"set_table_f or_f irst_display"的参数说明------------------------------------------------------------------------------|I_BUFFER_ACTIVE | 如果方法调用是静态的,可以设置这个标记,| | 这表示,如果每次显示ALV都是相同的字段目录.| | 既然这样,那么字段目录会被放到一个特殊的缓存里, | | 这样加速了ALV的显示------------------------------------------------------------------------------|I_STRUCTURE_NAME | 输出数据参考的数据字典的结构名,例如\'SFLIGHT\'.| | 如果指定了这个参数,字段目录会自动生成,下面的参数| | IT_FIELDCATALOG不需要传值.------------------------------------------------------------------------------|IS_VARIANT | 决定布局显示的变式------------------------------------------------------------------------------|I_SAVE | 决定用户是否可以保存变式:| | 'X' 只能保存全局变式| | 'U' 只能保存特定变式| | 'A' 都可以保存| | SPACE 不可以保存变式------------------------------------------------------------------------------|I_DEF AULT | 决定用户是否可以定义默认的布局:| | 'X' 可以定义默认布局,这个参数是默认的| | SPACE 不可以定义默认布局------------------------------------------------------------------------------|IS_LAYOUT | 布局参数,传递布局控制的一些信息------------------------------------------------------------------------------|IS_PRINT | 后台打印属性的参数------------------------------------------------------------------------------|IT_SPECIAL_GR OUPS | 如果在字段目录中,一些字段通过SP_GR OUP被分组在一起. | | 我们就必须为这些组传递一个组的文本内表进去------------------------------------------------------------------------------|IT_TOOLB AR_EX CLUDING| 需要隐藏的标准的按钮的内表------------------------------------------------------------------------------|IT_HYPERLINK | 为每个句柄分配了超连接的内表,| | LVC_S_HYPE中的HREF存放了超连接的地址,| | HANDLE指定了句柄,使用这些句柄,你可以在GRID中使用超连接------------------------------------------------------------------------------|IT_ALV_GR APHICS | 比较复杂,没有用过,意思好象是可以在图表中显示ALV.------------------------------------------------------------------------------|IT_OUTTAB | 输出数据存放的内表,数据都是存放在这个内表里------------------------------------------------------------------------------|IT_FIELDCATALOG | 字段目录------------------------------------------------------------------------------|IT_S ORT | 排序的标准------------------------------------------------------------------------------|IT_FILTER | 过滤的标准------------------------------------------------------------------------------方法"REFRESH_TABLE_DIS PLAY"的参数说明------------------------------------------------------------------------------IS_STABLE 刷新的稳定性,有2个参数,一个是行,一个是列.如果设置了相应的值,那么对应的行,或者列,在刷新的时候,将会保持稳定,就是滚动条保持不动.------------------------------------------------------------------------------I_SOF T_REFRES H 这个参数只是在异常情况下被使用,如果设置了这个参数, 任何创建的合计,任何排序次序,任何为了显示数据而设置的过滤都将保持不变.这个是非常有意义的.例如:当然你没有修改数据内表里的数据而想刷新ALV,仅仅只是改变一下布局和字段目录.------------------------------------------------------------------------------第三步,获取要显示数据的字段目录.有两种方式.1.手动创建FOR M prepare_field_catalog CHANGING pt_f ieldcat TYPE lvc_t_f cat . DATA ls_f cat type lvc_s_f cat .ls_f cat-f ieldname = \'CARR ID\' .ls_f cat-inttype = \'C\' .ls_f cat-outputlen = \'3\' .ls_f cat-coltext = \'Carrier ID\' .ls_f cat-seltext = \'Carrier ID\' .APPEND ls_f cat to pt_f ieldcat .CLEAR ls_f cat .ls_f cat-f ieldname = \'CONNID\' .ls_f cat-ref_table = \'SFLIGHT\' .ls_f cat-ref_table = \'CONNID\' .ls_f cat-outputlen = \'3\' .ls_f cat-coltext = \'Connection ID\' .ls_f cat-seltext = \'Connection ID\' .APPEND ls_f cat to pt_f ieldcat .2.半自动的创建FOR M prepare_field_catalog CHANGING pt_f ieldcat TYPE lvc_t_f cat . DATA ls_f cat type lvc_s_f cat .CALL FUNCTION \'LVC_FIELDCATALOG_MERGE\'EXPOR TINGi_structure_name = \'SFLIGHT\'CHANGINGct_fieldcat = pt_fieldcat[]EX CEPTIONSinconsistent_interf ace = 1program_error = 2OTHERS = 3.IF sy-subrc <> 0.*--Exception handlingENDIF.LOOP AT pt_fieldcat INTO ls_f cat .CAS E pt_f ieldcat-fieldname .WHEN \'CARRID\' .ls_f cat-outpulen = \'10\' .ls_f cat-coltext = \'Airline Carrier ID\' .MODIFY pt_fieldcat FROM ls_f cat .WHEN \'PAYMENTSUM\' .ls_f cat-no_out = \'X\' .MODIFY pt_fieldcat FROM ls_f cat .ENDCAS E .ENDF ORM .第四步,设置布局FOR M prepare_layout CHANGING ps_layout TYPE lvc_s_layo.ps_layout-zebra = \'X\' .ps_layout-grid_title = \'Flights\' .ps_layout-smalltitle = \'X\' .ENDF ORM. " prepare_layout第五步,排除不需要的标准按钮(可选,这个是第一种方法,还有另外一种,在添加自定义的按钮的时候介绍) 在你的ALV上,如果你想排除一些你不想要的标准按钮,你可以把需要排除的按钮填入到表UI_F UNCTIONS中,然后传给 set_table_f or_first_display方法的参数"IT_TOOLB AR_EX CLUDING".这些按钮的功能码一般都可以通过查看类 cl_gui_alv_grid的常量属性中获取到,或者自己加个断点,在after_user_command事件中.如果你要隐藏全部的工具条,你可以把layout中的no_toolbar设置为"X".FOR M exclude_tb_functions CHANGING pt_exclude TYPE ui_functions .DATA ls_exclude TYPE ui_func.ls_exclude = cl_gui_alv_grid=>mc_f c_maximum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_minimum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_subtot .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_average .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_subtot .ENDF ORM .按照上面的步骤,一个ALV的DEMO基本可以创建了.下面我们将讲述一些功能.功能一:在第一次显示以后,修改字段目录和布局.在运行的时候,很有可能需要在显示之后,需要设置一个新的布局或者字段目录.有下面这些方法去实现. 字段目录: get_frontend_f ieldcatalogs et_f rontend_fieldcatalog布局: get_frontend_layouts et_f rontend_layout使用这些方法,你在执行的任何时候,可以获取这些内容,然后修改他们.DATA ls_f cat TYPE lvc_s_f cat .DATA lt_f cat TYPE lvc_t_f cat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_f rontend_fieldcatalogIMPORTINGet_f ieldcatalog = lt_f cat[] .LOOP AT lt_f cat INTO ls_f cat .IF ls_f cat-f ieldname = \'PAYMENTS UM\' .ls_f cat-no_out = s pace .MODIF Y lt_f cat FROM ls_f cat .ENDIF .ENDLOOP .CALL METHOD gr_alvgrid->set_f rontend_fieldcatalogEXPOR TINGit_f ieldcatalog = lt_f cat[] .CALL METHOD gr_alvgrid->get_f rontend_layoutIMPORTINGes_layout = ls_layout .ls_layout-grid_title = \'Flights (w ith Payment Sums)\' .CALL METHOD gr_alvgrid->set_f rontend_layoutEXPOR TINGis_layout = ls_layout .功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构LVC_T_S OR T创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_f or_f irst_display这个方法的IT_S OR T参数来初始化一个排序.FOR M prepare_sort_table CHANGING pt_sort TYPE lvc_t_sort .DATA ls_sort TYPE lvc_s_sort .ls_sort-spos = \'1\' .ls_sort-f ieldname = \'CARRID\' .ls_sort-up = \'X\' . "A to Zls_sort-down = space .APPEND ls_sort TO pt_sort .ls_sort-spos = \'2\' .ls_sort-f ieldname = \'SEATS OCC\' .ls_sort-up = space .ls_sort-down = \'X\' . "Z to AAPPEND ls_sort TO pt_sort .ENDF ORM. " prepare_sort_table这有2点特别的说明:1.如果这边排序的字段名,不存在于字段目录中,那将出现DUMP.2.排序以后,垂直的网格中,如果出现相同的内容,就会合并,如果要避免,请在布局中设置"no_merging"为"X" .你可以通过使用方法“get_sort_c riteria” 和“set_sort_criteria”来获取和设置排序的标准.功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FILT"创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法"SET_TABLE_FOR_FIRS T_DIS PLAY"中的参数"IT_FILTER" FOR M prepare_filter_table CHANGING pt_f ilt TYPE lvc_t_f ilt .DATA ls_f ilt TYPE lvc_s_filt .ls_f ilt-fieldname = \'FLDATE\' .ls_f ilt-sign = \'E\' .ls_f ilt-option = \'BT\' .ls_f ilt-low = \'20030101\' .ls_f ilt-high = \'20031231\' .APPEND ls_f ilt TO pt_f ilt .ENDF ORM. " preparef iltertable我们可以使用"get_f ilter_criteria" 和"set_f ilter_criteria"来获取过滤条件和设置过滤条件.功能四:选择方式有时候,我们需要选择一些单元格,行或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.值模式可能的选择注释SPACE 等同于B 参考B 默认设置\'A\' 行和列的选择,无法选择单元格多行,多列用户可以使用最左边的选择按钮来选择多行\'B\' 单选,不可以多选行,不可以多选单元格多行,多列\'C\' 多选,可以多选行,不可以多选单元格多行,多列\'D\' 单元格的选择,可以多选单元格多行,多列,任何单元格多选用户可以使用最左边的选择按钮来选择多行注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择方式的设置的.2.设置了选择方式以后,我们可以使用很多方法来获取用户的选择.比如"GET_S ELECTED_CELLS","GET_SELECTED_CELLS_ID","GET_S ELECTED_ROWS","GET_SELECTED_COLUMNS"3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PB O中,使用对应的SET方法来恢复这些选择.功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cxyz---Color || || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第一位,第二位代表是颜色编码(1到7),第三位是加强的设置,第四位是相反,个人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:x 颜色主要使用在1Gray-blue headers2Light gray List bodies3yellow totals4Blue-green Key columns5green Positive threshold value6red Negative threshold value7orange Control levelsA)设置列的颜色.我们可以通过字段目录的"emphasize"控制字段来控制某列的颜色.这个字段同样是4位的CHAR型,传入上述的颜色编码.例如:LS_FCAT-EMPHAS IZE = \'C701\'.如果这列被设置为关键列,就是 LS_FCAT-K EY = \'X\' ,那么颜色设置就不会起作用.请注意,自动产生的字段目录中,KEY的设置是自动获取的.B)设置行的颜色为某行设置颜色,是有点复杂的,我们需要在要显示的数据内表中增加一个字段,这个字段不需要在字段目录中存在.同样,这个字段也是4位的CHAR型,符合颜色编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA END OF gt_list .很明显,填入颜色编码以后,ALV怎么知道它是我们用来设置颜色的呢,在布局中,有个控制字段"INF O_FNAME",我们可以设置这个字段来告诉ALV,我们的颜色字段是哪个.ps_layout-inf o_fname = \'ROWCOLOR\'.请注意,这个字段随便你起名字,但是记住,一定是数据内表里的字段,而且这边设置的时候一定要大写.你可以在任何时候设置行的颜色,只需要去修改内表里的这个字段的值,但是记得,一定要刷新以后才起作用.C)设置单元格的颜色设置单元格和设置行的颜色,本质上没有什么大的区别,但是定位单元格需要2个参数.我们需要在数据内表中插入一个表类型的字段,这样我们的数据内表就变成了DEEP结构了,不过ALV是可以处理的.不需要担心.插入的这个表类型的类型为"LVC_T_S COL".里面有3个参数:FNAME告诉我们你需要设置的是哪个字段,如果为空,然后直接在COLOR中设置颜色,就是整行设置为这个颜色.如果具体到某个单元格,必须指定是哪个字段.COLOR字段是用来设置颜色的.NOK EYCOL字段比较关键了.设置为关键列的一些字段,我们的颜色设置可能被覆盖.通过这个字段的设置,可以避免被关键列覆盖.同样,ALV在布局中有个字段"CTAB_FNAME"告诉我们,数据内表中,哪个字段是用来设置单元格的颜色的.DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA END OF gt_list .DATA ls_cellcolor TYPE lvc_s_scol ....READ TABLE gt_list INDEX 5 .ls_cellcolor-fname = \'SEATS OCC\' .ls_cellcolor-color-col = \'7\' .ls_cellcolor-color-int = \'1\' .APPEND ls_cellcolor TO gt_list-cellcolors .MODIF Y gt_list INDEX 5 .注意:颜色设置中有优先级顺序,他们是单元格--->行--->列.功能六:插入超链接插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为"LVC_T_HYPE" ,句柄是一个INT4类型的字段,我们需要在数据显示的内表中,加入这样的字段,来告诉ALV,我们的字段指定的句柄,从而找到对应的超级链接.在字段目录中,WEB_FIELD是用来指定对应的句柄名的. 下面举个例子来说明,我们要为字段CARRID,CONNID建立超级链接:首先,内表定义中,我们加入2个句柄字段:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA carrid_handle TYPE int4 .DATA connid_handle TYPE int4 .DATA END OF gt_list .第二: 建立一个超级链接内表,里面存放句柄所对应的超级链接.创建的时候注意,它参考的表类型,一定是"LVC_T_HYPE". FOR M prepare_hyperlinks_table CHANGING pt_hype TYPE lvc_t_hype .DATA ls_hype TYPE lvc_s_hype .ls_hype-handle = \'1\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'2\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'3\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'4\' .ls_hype-href = \'http://www.c /connids/con11\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'5\' .ls_hype-href = \'http://www.c /connids/con12\'APPEND ls_hype TO pt_hype ... ..ENDF ORM .第三.通过字段目录FIELDCATLOG来指定相应的句柄字段.对于CARRID的field catalogLs_fieldcat-w eb_field = …CARRID_HANDLE‟.对于CONNID的field catalogLs_fieldcat-w eb_field = …CONNID_HANDLE‟.在方法"SET_TABLE_F OR_FIRST_DISPLAY"中把句柄内表传给参数it_hyperlink。

ABAP4培训教程ALV

ABAP4培训教程ALV

ABAP4培训教程ALV
一、概述
ALV(ABAP List Viewer)是SAP系统中用于显示报表的一种强大技术,它引入了这一技术,使报表显示的更加友好,而不仅仅是一个简单的表格。

在ALV报表培训中,我们将学习如何创建一个ALV报表,以及如何灵活地操纵ALV报表。

二、基本概念
1、结构
ALV报表由一个最外层的结构,称为ALV对象结构,以及多个内嵌的结构组成。

ALV对象结构是一个单独的结构,它定义了报表的外观,如标题、数据表等。

2、属性
每个ALV对象结构都有多个属性,这些属性被称为ALV属性,它们定义了报表的处理过程。

例如,有关如何排序数据表中的数据,怎样展示列宽,如何处理表格字体等属性,都由ALV属性来实现。

3、事件
ALV还有一些预定义的事件,用于触发一些特定的事件,例如列表改变,行选择等。

这些事件可以用来调整报表的外观,或者在报表中增加额外的功能,以满足用户的具体需求。

三、ALV报表的创建与使用
1、创建ALV报表
要创建一个ALV报表,首先需要定义一个ALV对象结构,然后根据需要定义ALV属性和事件,最后,使用ALVAPI将数据填充到ALV中以完成报表的创建。

2、使用ALV报表。

ALV 详解

ALV 详解

一.ALV介绍The ALV Grid Control (ALV =S A P L ist V iewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用.SAP提示: 在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具,然而,目前这个功能只在实验计划中使用,还没有向客户发布.下面是一个ALV GRID的图片:它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏.ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV.二.ALV GRID CONTROL (ALV网格控制器)ALV GRID CONTROL使用了控制器技术以实现艺术性的屏幕显示,象所有的控制器一样,ALV GRID CONTROL法,以响应它的动作.使用了ABAP的对象以后,列表是通过ALV的一个实例(INSTANCE)来显示的,程序员可以使用ABAP对象的事件管理.三.ALV GRID CONTROL 实例ALV GRID实例的定义,参照CL_GUI_ALV_GRID类data ALV_GRID1 type ref to cl_gui_alv_grid.ALV GRID继承结构:四、ALV GRID相关的几个控制结构1.字段目录 [Field catalog]字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCT URE LVC_S_FCAT)93INDX_ROUND 自然数 94INDX_DECML 自然数 95GET_STYLE 字符字段长度 1 96MARK字符字段长度 12.布局控制[layout]布局是用来控制整个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 如果被设置,选择列在选择模式为D 和A 的时候隐藏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个字符3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SORT]过滤的参数控制请参考结构[LVC_S_FILT]这里不再一一解释,进入中文版本,里面应该也有解释的,虽然一些不是很清楚.五.编写简单的ALV程序.首先这里就不详细介绍DIALOG的用法了.OO的ALV GRID必须存在于一个容器当中,就是FUNCTION的ALV,其实也是一样的,底层也是使用CL_GUI_ALV_GRID这个类的.首先ALV的显示需要有几个先决条件.1,字段目录,这个是必须的,如果没有这个参数,参考一个数据字典也是可以的,就是参数I_STRUCTUR E_NAME.2.存放数据的内表,最好内表的结构和字段目录是一致的,否则可能会出现一些无法预知的错误,当然你说我非要不一样,那也不一定会出现错误.我建议是最好一样的.这2个是必须的,布局的话,应该是可以不设置的,使用默认的就可以了.第一步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量.DATA:WCL_CONTAINER TYPE REF TO CL_GUI_CUSTOM_CONTAINER,WCL_ALV TYPE REF TO CL_GUI_ALV_GRID .*--- 存放字段目录的内表DATA gt_fieldcat TYPE lvc_t_fcat .*--- 布局结构DATA gs_layout TYPE lvc_s_layo .*----声明需要显示的内表(以SFLIGHT为例)DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA END OF gt_list .第二步: 创建ALV这个对象,它的父组件是那个容器.在PBO中写入如下代码:PROCESS BEFORE OUTPUT .MODULE display_alv .创建DISPLAY_ALV的MODULE后,写下如下代码:MODULE display_alv OUTPUT .PERFORM display_alv .ENDMODULE .在FORM DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建:IF WCL_ALV IS INITIAL .CREATE OBJECT: WCL_CONTAINEREXPORTINGCONTAINER_NAME = 'ALV_CON'.CREATE OBJECT WCL_ALVEXPORTINGI_PARENT = WCL_CONTAINER.*-----准备获取字段目录PERFORM prepare_field_catalog CHANGING gt_fieldcat .*-----设置布局PERFORM prepare_layout CHANGING gs_layout .*-----显示ALVCALL METHOD gr_alvgrid->set_table_for_first_display EXPORTING* I_BUFFER_ACTIVE =* I_CONSISTENCY_CHECK =* I_STRUCTURE_NAME =* IS_VARIANT =* I_SAVE =* I_DEFAULT = 'X'is_layout = gs_layout* IS_PRINT =* IT_SPECIAL_GROUPS =* IT_TOOLBAR_EXCLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_list[]it_fieldcatalog = gt_fieldcat* IT_SORT =* IT_FILTER =EXCEPTIONSinvalid_parameter_combination = 1program_error = 2too_many_lines = 3OTHERS = 4 .ELSE .*----刷新ALVCALL METHOD gr_alvgrid->refresh_table_display * EXPORTING* IS_STABLE =* I_SOFT_REFRESH =EXCEPTIONSfinished = 1OTHERS = 2 .IF sy-subrc <> 0.*--异常处理ENDIF.ENDIF .方法"set_table_for_first_display"的参数说明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过滤的标准方法"REFRESH_TABLE_DISPLAY"的参数说明参数含义IS_STABLE 刷新的稳定性,有2个参数,一个是行,一个是列.如果设置了相应的值,那么对应的行,或者列,在刷新的时候,将会保持稳定,就是滚动条保持不动.I_SOFT_REFRESH 这个参数只是在异常情况下被使用,如果设置了这个参数,任何创建的合计,任何排序次序,任何为了显示数据而设置的过滤都将保持不变.这个是非常有意义的.例如:当然你没有修改数据内表里的数据而想刷新ALV,仅仅只是改变一下布局和字段目录.第三步,获取要显示数据的字段目录.有两种方式.1.手动创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat . DATA ls_fcat type lvc_s_fcat .ls_fcat-fieldname = 'CARRID' .ls_fcat-inttype = 'C' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Carrier ID' .ls_fcat-seltext = 'Carrier ID' .APPEND ls_fcat to pt_fieldcat .CLEAR ls_fcat .ls_fcat-fieldname = 'CONNID' .ls_fcat-ref_table = 'SFLIGHT' .ls_fcat-ref_table = 'CONNID' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Connection ID' .ls_fcat-seltext = 'Connection ID' .APPEND ls_fcat to pt_fieldcat .ENDFORM .2.半自动的创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat .DATA ls_fcat type lvc_s_fcat .CALL FUNCTION 'LVC_FIELDCATALOG_MERGE'EXPORTINGi_structure_name = 'SFLIGHT'CHANGINGct_fieldcat = pt_fieldcat[]EXCEPTIONSinconsistent_interface = 1program_error = 2OTHERS = 3.IF sy-subrc <> 0.*--Exception handlingENDIF.LOOP AT pt_fieldcat INTO ls_fcat .CASE pt_fieldcat-fieldname .WHEN 'CARRID' .ls_fcat-outpulen = '10' .ls_fcat-coltext = 'Airline Carrier ID' .MODIFY pt_fieldcat FROM ls_fcat .WHEN 'PAYMENTSUM' .ls_fcat-no_out = 'X' .MODIFY pt_fieldcat FROM ls_fcat .ENDCASE .ENDLOOP .ENDFORM .第四步,设置布局FORM prepare_layout CHANGING ps_layout TYPE lvc_s_layo.ps_layout-zebra = 'X' .ps_layout-grid_title = 'Flights' .ps_layout-smalltitle = 'X' .ENDFORM. " prepare_layout第五步,排除不需要的标准按钮(可选,这个是第一种方法,还有另外一种,在添加自定义的按钮的时候介绍)在你的ALV上,如果你想排除一些你不想要的标准按钮,你可以把需要排除的按钮填入到表UI_FUNC TIONS中,然后传给set_table_for_first_display方法的参数"IT_TOOLBAR_EXCLUDING".这些按钮的功能码一般都可以通过查看类cl_gui_alv_grid的常量属性中获取到,或者自己加个断点,在after_us er_command事件中.如果你要隐藏全部的工具条,你可以把layout中的no_toolbar设置为"X".FORM exclude_tb_functions CHANGING pt_exclude TYPE ui_functions .DATA ls_exclude TYPE ui_func.ls_exclude = cl_gui_alv_grid=>mc_fc_maximum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_minimum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_subtot .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_average .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_subtot .ENDFORM .按照上面的步骤,一个ALV的DEMO基本可以创建了.下面我们将讲述一些功能.功能一:在第一次显示以后,修改字段目录和布局.在运行的时候,很有可能需要在显示之后,需要设置一个新的布局或者字段目录.有下面这些方法去实现.字段目录: get_frontend_fieldcatalogset_frontend_fieldcatalog布局:get_frontend_layoutset_frontend_layout使用这些方法,你在执行的任何时候,可以获取这些内容,然后修改他们.DATA ls_fcat TYPE lvc_s_fcat .DATA lt_fcat TYPE lvc_t_fcat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_frontend_fieldcatalogIMPORTINGet_fieldcatalog = lt_fcat[] .LOOP AT lt_fcat INTO ls_fcat .IF ls_fcat-fieldname = 'PAYMENTSUM' .ls_fcat-no_out = space .MODIFY lt_fcat FROM ls_fcat .ENDIF .ENDLOOP .CALL METHOD gr_alvgrid->set_frontend_fieldcatalogEXPORTINGit_fieldcatalog = lt_fcat[] .CALL METHOD gr_alvgrid->get_frontend_layoutIMPORTINGes_layout = ls_layout .ls_layout-grid_title = 'Flights (with Payment Sums)' .CALL METHOD gr_alvgrid->set_frontend_layoutEXPORTINGis_layout = ls_layout .功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构LVC_T_SORT创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_for_first_display这个方法的IT_SORT参数来初始化一个排序.FORM prepare_sort_table CHANGING pt_sort TYPE lvc_t_sort .DATA ls_sort TYPE lvc_s_sort .ls_sort-spos = '1' .ls_sort-fieldname = 'CARRID' .ls_sort-up = 'X' . "A to Zls_sort-down = space .APPEND ls_sort TO pt_sort .ls_sort-spos = '2' .ls_sort-fieldname = 'SEATSOCC' .ls_sort-up = space .ls_sort-down = 'X' . "Z to AAPPEND ls_sort TO pt_sort .ENDFORM. " prepare_sort_table这有2点特别的说明:1.如果这边排序的字段名,不存在于字段目录中,那将出现DUMP.2.排序以后,垂直的网格中,如果出现相同的内容,就会合并,如果要避免,请在布局中设置"no_mer ging"为"X" .你可以通过使用方法“get_sort_criteria” 和“set_sort_criteria”来获取和设置排序的标准.功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FILT"创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法"SET_TABLE_FOR_FIRST_DISPLAY"中的参数"IT_FILTER"FORM prepare_filter_table CHANGING pt_filt TYPE lvc_t_filt .DATA ls_filt TYPE lvc_s_filt .ls_filt-fieldname = 'FLDATE' .ls_filt-sign = 'E' .ls_filt-option = 'BT' .ls_filt-low = '20030101' .ls_filt-high = '20031231' .APPEND ls_filt TO pt_filt .ENDFORM. " preparefiltertable我们可以使用"get_filter_criteria" 和"set_filter_criteria"来获取过滤条件和设置过滤条件.功能四:选择方式有时候,我们需要选择一些单元格,行或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.值模式可能的选择注释SPACE等同于B参考B默认设置'A'行和列的选择,无法选择单元格多行,多列用户可以使用最左边的选择按钮来选择多行'B'单选,不可以多选行,不可以多选单元格多行,多列'C'多选,可以多选行,不可以多选单元格多行,多列'D'单元格的选择,可以多选单元格多行,多列,任何单元格多选用户可以使用最左边的选择按钮来选择多行注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择方式的设置的.2.设置了选择方式以后,我们可以使用很多方法来获取用户的选择.比如"GET_SELECTED _CELLS","GET_SELECTED_CELLS_ID","GET_SELECTED_ROWS","GET_SEL ECTED_COLUMNS"3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PBO中,使用对应的S ET方法来恢复这些选择.功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cx y z---Color | | || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第一位,第二位代表是颜色编码(1到7),第三位是加强的设置,第四位是相反,人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:x颜色主要使用在1Gray-blue headers2Light gray List bodies3yellow totals4Blue-green Key columns5green Positive threshold value6red Negative threshold value7orange Control levelsA)设置列的颜色.我们可以通过字段目录的"emphasize"控制字段来控制某列的颜色.这个字段同样是4位的CHAR型,传入上述的颜色编码.例如:LS_FCAT-EMPHASIZE = 'C701'.如果这列被设置为关键列,就是 LS_FCAT-KEY = 'X' ,那么颜色设置就不会起作用.请注意,自动产生的字段目录中,KEY的设置是自动获取的.B)设置行的颜色为某行设置颜色,是有点复杂的,我们需要在要显示的数据内表中增加一个字段,这个字段不需要在字段目录中存在.同样,这个字段也是4位的CHAR型,符合颜色编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA END OF gt_list .很明显,填入颜色编码以后,ALV怎么知道它是我们用来设置颜色的呢,在布局中,有个控制字段"INFO_FNAME",我们可以设置这个字段来告诉ALV,我们的颜色字段是哪个.ps_layout-info_fname = 'ROWCOLOR'.请注意,这个字段随便你起名字,但是记住,一定是数据内表里的字段,一定要大写.你可以在任何时候设置行的颜色,只需要去修改内表里的这个字段的值,但是记得一定要刷新以后才起作用.C)设置单元格的颜色设置单元格和设置行的颜色,本质上没有什么大的区别,但是定位单元格需要2个参数.我们需要在数据内表中插入一个表类型的字段,这样我们的数据内表就变成了DEEP结构了,不过ALV是可以处理的.不需要担心.插入的这个表类型的类型为"LVC_T_SCOL".里面有3个参数:FNAME告诉我们你需要设置的是哪个字段,如果为空,然后直接在COLOR中设置颜色,就是整行设置为这个颜色.如果具体到某个单元格,必须指定是哪个字段.COLOR字段是用来设置颜色的.NOKEYCOL字段比较关键了.设置为关键列的一些字段,我们的颜色设置可能被覆盖.通过这个字段的设置,可以避免被关键列覆盖.同样,ALV在布局中有个字段"CTAB_FNAME"告诉我们,数据内表中,哪个字段是用来设置单元格的颜色的.DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA END OF gt_list .DATA ls_cellcolor TYPE lvc_s_scol ....READ TABLE gt_list INDEX 5 .ls_cellcolor-fname = 'SEATSOCC' .ls_cellcolor-color-col = '7' .ls_cellcolor-color-int = '1' .APPEND ls_cellcolor TO gt_list-cellcolors .MODIFY gt_list INDEX 5 .注意:颜色设置中有优先级顺序,他们是单元格--->行--->列.功能六:插入超链接插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为"LVC_T_HYPE" ,句柄是一个INT4类型的字段,我们需要在数据显示的内表中,加入这样的字段,来告诉ALV,我们的字段指定的句柄,从而找到对应的超级链接.在字段目录中,WEB_FIELD是用来指定对应的句柄名的.下面举个例子来说明,我们要为字段CARRID,CONNID建立超级链接:首先,内表定义中,我们加入2个句柄字段:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA carrid_handle TYPE int4 .DATA connid_handle TYPE int4 .DATA END OF gt_list .第二: 建立一个超级链接内表,里面存放句柄所对应的超级链接.创建的时候注意,它参考的表类型,一定是"LVC_T_HYPE".FORM prepare_hyperlinks_table CHANGING pt_hype TYPE lvc_t_hype . DATA ls_hype TYPE lvc_s_hype .ls_hype-handle = '1' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '2' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '3' .ls_hype-href = '/carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '4' .ls_hype-href = '/connids/con11' .APPEND ls_hype TO pt_hype .ls_hype-handle = '5' .ls_hype-href = '/connids/con12'APPEND ls_hype TO pt_hype ... ..ENDFORM .第三.通过字段目录FIELDCATLOG来指定相应的句柄字段.对于CARRID的field catalogLs_fieldcat-web_field = ‘CARRID_HANDLE’.对于CONNID的field catalogLs_fieldcat-web_field = ‘CONNID_HANDLE’.在方法"SET_TABLE_FOR_FIRST_DISPLAY"中把句柄内表传给参数it_hyperlink。

alv各种设置

alv各种设置

alv各种设置⽬录1.将得到并整理好的数据以ALV的形式显⽰出来 (4)1.1.在⼦FORM(这⾥如:F_FIELDS)指定需要显⽰的字段 (4)1.2.在⼦FORM(这⾥如:F_BUILD_LAYOUT)⾥设置ALV的全局属性 (4)1.3.在⼦FORM(这⾥如:F_DISPLAY)⾥将内表中的数据进⾏显⽰ (5)1.4.为ALV程序添加表头标题(这⾥以添加HTML表头标题为主) (5)1.4.1.在显⽰ALV的函数(REUSE_ALV_GRID_DISPLAY_LVC)⾥添加⼀个参数 (5) 1.4.2.在⼦FORM(F_TOP_OF_PAGE)⾥定义好需要的变量 (5)1.4.3.准备好所需数据,如登录⽤户的描述、制表⽇期等 (6)1.4.4.将表头数据输出 (6)2.函数“REUSE_ALV_GRID_DISPLAY_LVC”中输⼊参数的应⽤ (7)2.1.排序 (7)2.1.1.在显⽰ALV的⼦FORM⾥定义排序⽤到的变量 (7)2.1.2.设置好需要排序的字段 (8)2.1.3.在显⽰ALV的函数的输⼊参数⾥添加排序的属性 (8)2.2.隐藏不必要的标准按钮 (8)2.2.1.先在显⽰ALV的⼦FORM⾥定义隐藏按钮⽤到的变量 (8)2.2.2.得到需要隐藏的标准按钮的“FCODE” (8)2.3.⾃定义“⼯具栏” (9)2.3.1.在显⽰ALV的函数的输⼊参数⾥指定⾃定义按钮的⼦FORM (9)3.热点链接、⽤户动作的捕捉、调⽤其他程序或标准事务程序 (11)3.1.在显⽰ALV的函数的输⼊参数⾥指定捕捉⽤户动作的⼦FORM (11)3.2.在“字段和列名”的⼦FORM(F_FIELDS)⾥,对需要链接的列添加“热点”属性 (11) 3.3.操作代码 (11)3.4.显⽰具体细节 (12)3.5.调⽤其他事务 (14)3.6.打开并选择⽂件: (14)4.关于设置字段和列名的⼦FORM(F_FIELDS)的参数设置: (15)4.1.单列优化宽度 (15)4.2.单列求和或者取消求和,添加属性 (15)4.3.对其⽅式 (16)4.4.作为图标输出 (16)4.5.固定列和关键列 (16)4.6.列的字符宽度 (17)5.单元格的F1、F4帮助: (17)5.1.F1帮助: (17)5.2.F4帮助: (17)6.输⼊并保存、回调修改内表(输⼊时的⼩数位错位的问题、指定数据类型、⼩说位数) (17)7.界⾯颜⾊的更改 (19)7.1.更改单元格(字体)的前景、背景颜⾊ (19)7.2.更改⾏的颜⾊和列的颜⾊: (19)7.3.利⽤设置字段和列名⼦的FORM(F_FIELDS)⾥来设置列的颜⾊ (20)8.ALV⾃带的最左端复选框按钮和⾃定义复选框按钮 (20)8.1.ALV⾃带的复选框按钮: (20)8.2.⾃定义复选框按钮 (21)9.按照上传的模板格式导出为本地⽂件 (21)9.1.定义导出为EXCEL⽤到的数据变量 (21)9.2.上传模板 (21)9.3.代码 (22)10.为ALV标题添加图⽚ (27)10.1.上传图⽚ (27)10.2.在⼦FORM(F_TOP_OF_PAGE2)⾥的代码 (27)ALV:SAP LIST VIEW,⼀种⽐较美观的报表显⽰⼯具ALV⽤到的函数,⽬前我们有2个:REUSE_ALV_GRID_DISPLAY、REUSE_ALV_GRID_DISPLAY_LVC;两个函数都可以将数据⽤ALV的形式显⽰出来,只是⽅在⼀些⼩的地⽅有些不同。

abap alv使用手册

abap alv使用手册

abap alv使用手册ABAP(Advanced Business Application Programming)是SAP系统中用于开发报表和程序的语言。

ALV(ABAP List Viewer)是SAP提供的一种报表工具,使用户能够以友好的方式显示数据。

在使用ALV之前,需要了解一些基础知识。

首先,你需要知道ALV的三种类型:内联、表格和交互式表格。

每种类型都有其特定的用途和优点。

其次,你需要了解ALV的三个主要组件:数据结构、显示属性和列属性。

数据结构定义了报表的数据来源,显示属性定义了报表的外观,列属性定义了列的行为和格式。

创建ALV报表需要遵循以下步骤:1.创建数据模型:数据模型定义了报表的数据来源。

你需要选择一个内表作为数据源,并为内表创建相应的数据模型。

数据模型包括字段名称、数据类型和关键字等属性。

2.创建显示格式:显示格式定义了报表的外观。

你需要选择一个合适的显示格式,并为格式创建相应的列。

列的属性包括标题、数据类型、宽度和格式等。

3.添加列到报表:将列添加到报表中,并根据需要进行调整。

你可以使用列属性来定义列的行为和格式,例如排序、过滤和汇总等。

4.运行报表:保存并运行报表,查看结果是否符合预期。

如果需要,可以进行调整和优化。

5.除了上述步骤,还有一些高级功能可以使用。

例如,你可以使用ALV的交互式功能,使用户能够编辑和修改报表中的数据。

你还可以使用ALV的过滤器功能,根据需要筛选数据。

此外,ALV还支持多种格式的输出,例如Excel、PDF和HTML 等。

总之,ABAP ALV是一个强大的报表工具,使用户能够轻松地显示和管理数据。

通过掌握基础知识和使用步骤,你可以快速创建出符合需求的报表,提高工作效率和数据质量。

同时,不断学习和探索高级功能,可以使你在开发报表时更加得心应手,发挥出ALV的最大优势。

在使用ABAP ALV时,需要注意一些常见问题和陷阱。

例如,确保数据模型和显示格式的正确配置,避免出现数据不匹配或显示异常的情况。

ALV中的fieldcat常用以及大全

ALV中的fieldcat常用以及大全

字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的字段如下:row_pos: 默认值为0,可选值为1、2、3,既最大分3级别显示fieldname 字段的名字(内表中定义的字段名)ref_field (ALV 控制: 内部表字段的参考字段名称) 参考的数据字典的字段名,配合ref_tabname一起使用,一般用来使单元格生成F4帮助ref_table (ALV 控制: 内部表字段的参考表名称) 参考数据字典的表名,配合ref_fieldname使用fieldname ALV 控制: 内部表字段的字段名称TABNAME LVC 标签名称Cfieldname currency unit field name值为当前输出内表中的货币单位字段的字段名称Ctabname Cfieldname字段值对应的输出内表Qfieldname 计量单位字段名,例如如值EA对应的字段名Qtabname Qfieldname 对应的输出内表名COLTEXT ALV 控制: 列标题key 字段是否为关键字(X或空)checkbox 复选框形式(X或空)ICON 作为图标输出,在ALV输出内表中的字段内容必须是有效的图标名称,图标名称和ID存在数据字典中ICON表中。

OUTPUTLEN ALV 控制: 列的字符宽度edit 当前列可编辑emphasize 设置列的颜色。

取值格式C(1-7)(0-1)(0-1)当有字段的edit属性生效时,会与该参数值想冲突。

edit_mask 同write语句中的edit mask格式是一样的,一般用来格式化时间和日期等col_pos 字段的位置no_out 当前列隐藏输出just 对齐方式(取值为R,L,C)lzero 输出前导零(X或空),仅NUMC类型字段有效no_zero 如果取值为零,则为空,既不输出零。

do_sum 对当前列输出时自动求和scrtext_l 字段的文本描述,输出时候显示。

alv的列、行和单元格控制

alv的列、行和单元格控制

1.ALV某列可以编辑.很简单在FIELDCAT中设置EDIT属性为X就可以了。

2.ALV某行可以编辑.要在ALV数据内表中添加一个字段参考内表类(LVC_T_STYL)并且在ALV的LAYOUT部分指示出控制是否可编辑的字段名字3.ALV某个单元格可以编辑.控制单元格和行的控制一样如果控制到行和单元格,就不能用以前那个’REUSE_ALV_GRID_DISPLAY’了,要用增强的函数‘REUSE_ALV_GRID_DISPLAY_LVC’.INCLUDE <icon>.INCLUDE <symbol>.TYPE-POOLS:slis.TABLES:SPFLI.TYPES:BEGIN OF TYP_SPFLI,CARRID TYPE SPFLI-CARRID,CONNID TYPE SPFLI-CONNID,COUNTRYFR TYPE SPFLI-COUNTRYFR,COUNTRYTO TYPE SPFLI-COUNTRYTO,CITYFROM TYPE SPFLI-CITYFROM,CITYTO TYPE SPFLI-CITYTO,END OF TYP_SPFLI,BEGIN OF TYP_OUTPUT,ICON TYPE icon_d,SYMBOL TYPE icon_d,CARRID TYPE SPFLI-CARRID,CONNID TYPE SPFLI-CONNID,COUNTRYFR TYPE SPFLI-COUNTRYFR,COUNTRYTO TYPE SPFLI-COUNTRYTO,CITYFROM TYPE SPFLI-CITYFROM,CITYTO TYPE SPFLI-CITYTO,STYLE TYPE LVC_T_STYL, “FOR DISABLEEND OF TYP_OUTPUT.DATA:TH_SPFLI TYPE TYP_SPFLI,TD_SPFLI TYPE TABLE OF TYP_SPFLI,TH_STYLE TYPE LVC_S_STYL,TD_STYLE TYPE TABLE OF LVC_S_STYL,TH_LAYOUT TYPE LVC_S_LAYO,TH_FIELDCAT TYPE LVC_S_FCAT,TD_FIELDCAT TYPE TABLE OF LVC_S_FCAT, TH_OUTPUT TYPE TYP_OUTPUT,TD_OUTPUT TYPE TABLE OF TYP_OUTPUT. START-OF-SELECTION.SELECT-OPTIONS:S_CARRID FOR SPFLI-CARRID,S_CONNID FOR SPFLI-CONNID.PERFORM FRM_GET_DATA.PERFORM FRM_EDIT_DATA.PERFORM FRM_DISPLAY_DATA.*&———————————————————————* *& Form FRM_GET_DATA*&———————————————————————* * GET MAIN DATA*———————————————————————-* FORM FRM_GET_DATA .SELECT CARRIDCONNIDCOUNTRYFRCOUNTRYTOCITYFROMCITYTOINTO TABLE TD_SPFLIFROM SPFLIWHERE CARRID IN S_CARRIDAND CONNID IN S_CONNID.IF SY-SUBRC <> 0.MESSAGE S001 DISPLAY LIKE ‘E’.LEAVE LIST-PROCESSING.ENDIF.ENDFORM. ” FRM_GET_DATA*&———————————————————————* *& Form FRM_DISPLAY_DATA*&———————————————————————* * text *———————————————————————-** –> p1 text* <–p2 text *———————————————————————-* FORM FRM_DISPLAY_DATA .PERFORM FRM_SET_TITLE.PERFORM FRM_SET_FIELDCAT.PERFORM FRM_CALL_FUNCTION. ENDFORM. ” FRM_DISPLAY_DATA*&———————————————————————**& Form FRM_SET_TITLE*&———————————————————————** text *———————————————————————-** –> p1 text* <–p2 text *———————————————————————-* FORM FRM_SET_TITLE .TH_LAYOUT-STYLEFNAME = ‘STYLE’.TH_LAYOUT-GRID_TITLE = ‘行列单元格编辑控制’. TH_LAYOUT-CWIDTH_OPT = ‘X’.ENDFORM. ” FRM_SET_TITLE*&———————————————————————**& Form FRM_SET_FIELDCAT*&———————————————————————** text*———————————————————————-** –> p1 text* <–p2 text *———————————————————————-*FORM FRM_SET_FIELDCAT .PERFORM FRM_SET_VALUE USING ‘1′ ‘ICON’‘ICON’ ‘5′ ‘ ‘.PERFORM FRM_SET_VALUE USING ‘2′ ‘SYMBOL’ ‘SYMBOL’ ‘5′ ‘ ‘. PERFORM FRM_SET_VALUE USING ‘3′ ‘CARRID’ ‘航线承运人ID’ ‘3′ ”. PERFORM FRM_SET_VALUE USING ‘4′ ‘CONNID’ ‘航班连接Id’ ‘4′ ”. PERFORM FRM_SET_VALUE USING ‘5′ ‘COUNTRYFR’ ‘国家代码FROM’ ‘3′ ”. PERFORM FRM_SET_VALUE USING ‘6′ ‘COUNTRYTO’ ‘国家代码TO’ ‘3′ ”. PERFORM FRM_SET_VALUE USING ‘7′ ‘CITYFROM’ ‘起飞城市’ ‘20′ ”. PERFORM FRM_SET_VALUE USING ‘8′ ‘CITYTO’ ‘目标城市’ ‘20′ ”. ENDFORM. ” FRM_SET_FIE LDCAT*&———————————————————————**& Form FRM_SET_VALUE*&———————————————————————** text*———————————————————————-** –>P_COL_POS text NO_ROWMARK* –>P_FIELDNAME text* –>P_SELTEXT_L text* –>P_OUTPUTLEN text *———————————————————————-* FORM FRM_SET_VALUE USING I_COL_POSI_FIELDNAMEI_SELTEXTI_OUTPUTLENI_CHECKBOX.TH_FIELDCAT-COL_POS = I_COL_POS.TH_FIELDCAT-FIELDNAME = I_FIELDNAME. TH_FIELDCAT-SCRTEXT_M = I_SELTEXT.TH_FIELDCAT-OUTPUTLEN = I_OUTPUTLEN. IF I_FIELDNAME = ‘CARRID’.TH_FIELDCAT-EDIT = ‘X’.ELSEIF I_FIELDNAME = ‘CHECK’.TH_FIELDCAT-SCRTEXT_M = ‘SELECT’.TH_FIELDCAT-CHECKBOX = ‘X’.TH_FIELDCAT-OUTPUTLEN = 1.TH_FIELDCAT-EDIT = ‘X’.ELSEIF I_FIELDNAME = ‘ICON’.TH_FIELDCAT-icon = ‘X’.ELSEIF I_FIELDNAME = ‘SYMBOL’.TH_FIELDCAT-symbol = ‘X’.ENDIF.APPEND TH_FIELDCAT TO TD_FIELDCAT.CLEAR TH_FIELDCAT.ENDFORM. ” FRM_SET_VALUE*&———————————————————————**& Form FRM_CALL_FUNCTION*&———————————————————————** text *———————————————————————-** –> p1 text* <–p2 text *———————————————————————-*FORM FRM_CALL_FUNCTION .* call function ‘REUSE_ALV_GRID_DISPLAY’CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY_LVC’EXPORTINGI_CALLBACK_PROGRAM = SY-REPIDI_CALLBACK_USER_COMMAND = ‘FRM_SET_COMMAND’IS_LAYOUT_LVC = TH_LAYOUTIT_FIELDCAT_LVC = TD_FIELDCATI_SAVE = ‘A’TABLEST_OUTTAB = TD_OUTPUTEXCEPTIONSPROGRAM_ERROR = 1OTHERS = 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.ENDFORM. ” FRM_CALL_FUNCTION*&———————————————————————**& Form FRM_EDIT_DATA*&———————————————————————** text *———————————————————————-** –> p1 text* <–p2 text *———————————————————————-*FORM FRM_EDIT_DATA .DATA:LW_INDEX TYPE SY-INDEX,LW_MOD TYPE I.LOOP AT TD_SPFLI INTO TH_SPFLI.LW_INDEX = SY-TABIX.LW_MOD = LW_INDEX MOD 3.IF LW_MOD <> 0.TH_OUTPUT-ICON = ICON_TIME.TH_OUTPUT-SYMBOL = SYM_LEFT_HAND.ELSE.TH_OUTPUT-ICON = ICON_COLOR.TH_OUTPUT-SYMBOL = sym_folder.ENDIF.IF TH_SPFLI-COUNTRYTO = ‘DE’ .PERFORM FRM_SET_ENABLED USING ‘COUNTRYTO’. PERFORM FRM_SET_ENABLED USING ‘CITYTO’. ENDIF.IF TH_SPFLI-CONNID = ‘2436′.PERFORM FRM_SET_ENABLED USING ‘COUNTRYFR’. PERFORM FRM_SET_ENABLED USING ‘CITYFROM’. ENDIF.IF TH_SPFLI-CARRID = ‘SQ’.PERFORM FRM_SET_DISABLED USING ‘CARRID’.ENDIF.IF TH_SPFLI-CARRID = ‘DL’.PERFORM FRM_SET_ENABLED USING ‘ICON’.PERFORM FRM_SET_ENABLED USING ‘SYMBOL’.PERFORM FRM_SET_ENABLED USING ‘CARRID’.PERFORM FRM_SET_ENABLED USING ‘CONNID’.PERFORM FRM_SET_ENABLED USING ‘COUNTRYFR’.PERFORM FRM_SET_ENABLED USI NG ‘COUNTRYTO’.PERFORM FRM_SET_ENABLED USING ‘CITYFROM ‘.PERFORM FRM_SET_ENABLED USING ‘CITYTO’. ENDIF.MOVE-CORRESPONDING TH_SPFLI TO TH_OUTPUT. TH_OUTPUT-STYLE[] = TD_STYLE[].REFRESH:TD_STYLE.APPEND TH_OUTPUT TO TD_OUTPUT.CLEAR:LW_INDEX,LW_MOD,TH_OUTPUT.ENDLOOP.ENDFORM. ” FRM_EDIT_DATAFORM FRM_SET_COMMAND USING r_ucomm LIKE sy-ucomm rs_selfield TYPE slis_selfield.CASE r_ucomm.WHEN ‘&IC1′. “双击事件* READ TABLE itab INTO wa INDEX rs_selfield-tabindex.** SET PARAMETER ID ‘BLN’ FIELD wa-belnr.* SET PARAMETER ID ‘BUK’ FIELD wa-bukrs.* SET PARAMETER ID ‘GJR’ FIELD wa-gjahr.** CALL TRANSACTION ‘FB03′ AND SKIP FIRST SCREEN.ENDCASE.ENDFORM.*&———————————————————————**& Form FRM_SET_ENABLED*&———————————————————————** text *———————————————————————-** –>P_0447 text *———————————————————————-*FORM FRM_SET_ENABLED USING I_NAME.TH_STYLE-FIELDNAME = I_NAME.TH_STYLE-STYLE = CL_GUI_ALV_GRID=>MC_STYLE_ENABLED. “set field to disabledAPPEND TH_STYLE TO TD_STYLE.CLEAR TH_STYLE.ENDFORM. ” FRM_SET_ENABLED*&———————————————————————**& Form FRM_SET_DISABLED*&———————————————————————** text *———————————————————————-** –>I_NAME text *———————————————————————-*FORM FRM_SET_DISABLED USING I_NAME.TH_STYLE-FIELDNAME = I_NAME.TH_STYLE-STYLE = CL_GUI_ALV_GRID=>MC_STYLE_DISABLED. “set field to disa bledAPPEND TH_STYLE TO TD_STYLE.CLEAR TH_STYLE.ENDFORM. ” FRM_SET_DISABLED。

ALV显示

ALV显示

一、ALV简介1、简介ALV――SAP LIST VIEWER是SAP中的一种报表方式,这里姑且称之为ABAP表单浏览器,用它可以标准化,简单化R/3系统中的表单,它可以提供给用户一个统一的表单格式及用户接口。

ALV是系统的一种网格的显示方式,这种方式带有汇总\排序\筛选等功能,ALV格式的数据是以单元格为单位显示,SAP提供了一套ALV 的功能模块,可以对输出报表的样式作修饰,提高报表输出的可读性和功能性,对于动态报表程序是一个很有效率的工具。

ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV。

一般的ALV报表有一个表头,再加上表内容,并附加一些如排序,分类汇总,合计或下载为本地文件等预设功能。

ALV报表显示方式基本上有2种,一种是Grid方式,一种是List方式,是分别调用不同的Function来实现。

1)当调用“REUSE_ALV_GRID_DISPLAY”函数时,ALV的显示样式如下:2)当调用“REUSE_ALV_LIST_DISPLAY”函数时,ALV的显示样式如下:2、ALV_GRID介绍The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用。

在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具。

它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏。

3、其它描述报表的自主开发设计主要逻辑都是依托于选择屏幕上字段,也就是提供给用户让他们得到自己想要结果的选择条件途径。

其中最重要的就是必选字段,因为必选字段是取数逻辑的精华所在,他可以很巧妙的限制很多非必要的情况出现,减少开发人员的开发量,还能让用户最直接最快捷的得到与实际业务相关的展现结果。

ALV常用参数

ALV常用参数

ALV常用参数ALV的常用参数描述调用功能模块:CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY’EXPORTINGI_INTERFACE_CHECK = '' 接口一致性检查I_CALLBACK_PROGRAM = SY-REPID 当前程序名IS_LAYOUT = G_LAYOUT 输出样式IT_FIELDCAT = G_FIELDCAT_ALV[] 字段定义描述表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[] 排序设置TABLEST_OUTTAB = IT_ALV[]EXCEPTIONSPROGRAM_ERROR = 1OTHERS = 2.常用属性:(赋值’’中内容必须为大写)1、IT_FIELDCATDATA: g_fieldcat_alv TYPE slis_t_fieldcat_alv WITH HEADER LINE.IT_FIELDCAT = G_FIELDCAT_ALV[] 字段定义描述表2、g_fieldcatDATA: g_fieldcat TYPE slis_fieldcat_alv.(用来定义表单中的各个列的相关信息)g_fieldcat-col_pos = n. 输出列g_fieldcat-fieldname = ‘FIELDNAME’.对应的内表字段名g_fieldcat-seltext_s/m/l = ‘列名’.输出列文本(_s:短文本、 _l:长文本)g_fieldcat-emphasize = ‘CX10’.带有颜色的高亮列其中X=(1-7)颜色同format)g_fieldcat-hotspot = ‘X’.作为热点显示,可触发鼠标触发事件g_fieldcat-currency = ‘CURRKEY’.表 TCURX 中的货币名称g_fieldcat-quantity(3) 计量单位g_fieldcat-qfieldname 参考计量单位的字段名称g_fieldcat-round = n. 四舍五入至小数位数下 n 位g_fieldcat-exponent = n. 浮点数的幂指数为ng_fieldcat-key = ‘X’.关键字段g_fieldcat-icon = ‘X’.作为图标输出g_fieldcat-symbol = ‘X’.输出作为符号g_fieldcat-checkbox = ‘X’.作为复选框输出g_fieldcat-just = SPACE, 'R', 'L', 'C'. 对齐方式g_fieldcat-lzero = ‘X’.输出前导零g_fieldcat-no_sign = ‘X’.输出抑制符号g_fieldcat-no_zero = ‘X’.为输出隐藏零g_fieldcat-edit_mask = SPACE, mask. 输出为mask的模式g_fieldcat-fix_column = ‘X’.固定列g_fieldcat-do_sum = ‘X’.总计列值总和g_fieldcat-no_out = ‘X’.列不输出g_fieldcat-tech = ‘X’.该字段为技术字段g_fieldcat-outputlen = n 列的字符宽度为ng_fieldcat-decimals_out = n 能控制小数点的位数为ng_fieldcat-datatype = C,I,N…定义数据类型3、SORTDATA: g_sortable TYPE slis_t_sortinfo_alv WITH HEADER LINE.it_sort = g_sortable[]属性attribute(排序)g_sortable-fieldname 字段名Up 升序排列Down 降序排列Subtot4、LAYOUTDADTA:g_layout TYPE slis_layout_alv .IS_LAYOUT = g_layout属性 (用于定义ALV表单的相关格式、属性)g_layout-info_fieldname = 'LINE_COLOR'. 设置特殊行颜色(将LINE_COLOR增加到内表字段,写'CX10'到特殊行的LINE_COLOR, X 为颜色值)g_layout-colwidth_optimize = ‘X’.优化列宽设置g_layout-no_colhead = 'X'. 不显示列名g_layout-no_vline = 'X'. 不显示列间竖线g_layout-f2code = '&ETA'. 设置触发弹出详细信息窗口的功能码,这里是双击g_layout-detail_popup 是否弹出详细信息窗口g_layout-detail_titlebar 设置弹出窗口的标题栏g_layout-totals_textg_layout-totals_onlyg_layout-group_change_editg_layout-header_text5、按钮DATA: i_events TYPE slis_t_event WITH HEADER LINE.it_events = g_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.功能代码: 函数文本: 图标名称:&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&OL0ALV_GRID介绍一、ALV介绍The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用。

alv单元格颜色

alv单元格颜色

alv单元格颜色(原创实用版)目录1.ALV 单元格的概述2.ALV 单元格颜色的设置方法3.ALV 单元格颜色的应用场景4.总结正文一、ALV 单元格的概述ALV(Area-based Linkage View)单元格是基于单元格的链接视图,常用于 SAP 等企业管理软件中,用于展示不同数据表之间的关联数据。

ALV 单元格可以包含各种数据类型,如字符、数字、日期等,并且可以进行格式化设置,以满足不同场景下的展示需求。

二、ALV 单元格颜色的设置方法在 SAP 中,可以通过以下步骤为 ALV 单元格设置颜色:1.选中需要设置颜色的 ALV 单元格;2.在工具栏中找到“格式”选项卡;3.在“格式”选项卡中找到“单元格”;4.在“单元格”下拉菜单中选择“属性”;5.在弹出的“单元格属性”窗口中,找到“背景”选项卡;6.在“背景”选项卡中,可以选择颜色、渐变或图像作为背景;7.设置完成后,点击“应用”按钮,即可保存设置。

三、ALV 单元格颜色的应用场景ALV 单元格颜色设置可以根据不同的业务需求和场景进行应用,以下是一些常见的应用场景:1.突出关键数据:对于一些关键的业务数据,可以通过设置醒目的颜色,使其在 ALV 视图中更加突出,便于用户快速定位和识别;2.区分不同数据类型:通过为不同数据类型的单元格设置不同颜色,可以增强视图的可读性,使用户更容易区分各类数据;3.显示错误或警告信息:在 ALV 单元格中显示错误或警告信息时,可以设置特殊的颜色,以便用户及时发现并处理问题;4.强调特定业务流程:在特定的业务流程中,可以通过设置 ALV 单元格颜色,使用户更加关注和了解相关业务环节。

四、总结ALV 单元格颜色设置是 SAP 等企业管理软件中一个实用的功能,可以根据不同业务场景和需求进行设置,以提高视图的可读性和易用性。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

ALV详细字段介绍ALV常用参数的详细描述调用功能模块:CALL FUNCTION \'REUS E_ALV_GRID_DIS PLAY\'EXPOR TINGi_interface_check = \'\' 接口一致性检查i_callback_program = sy-repid 当前程序名is_layout = layout 输出样式it_f ieldcat = 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[] 排序设置TABLESt_outtab = ig_outEX CEPTIONSprogram_error = 1OTHERS = 2.常用属性:(赋值‟‟中内容必须为大写)1. Fieldcatdata: fieldcat type slis_t_fieldcat_alv w ith header line.it_fieldcat = fieldcat[]属性(用来定义表单中的各个列的相关信息)Fieldcat-col_pos = n. 输出列Fieldcat-tabname = …FIELDNAME‟.对应的内表字段名Fieldcat-seltext_s/m/l = …列名‟. 输出列文本(_s:短文本 _l:长文本)Fieldcat-emphasize = …CX10‟.带有颜色的高亮列(其中X=(1-7)颜色同f ormat) Fieldcat-hotspot = …X‟.作为热点显示,可触发鼠标触发事件Fieldcat-c urrency = …CURRKEY‟.表 TCURX 中的货币名称 Fieldcat-quantity(3) 计量单位Fieldcat-qfieldname = '数量' 参考计量单位的字段名称 Fieldcat-round = n. 四舍五入至小数位数下n 位Fieldcat-exponent = n. 浮点数的幂指数为nFieldcat-key = …X‟.关键字段Fieldcat-icon = …X‟.作为图标输出Fieldcat-symbol = …X‟.输出作为符号Fieldcat-checkbox = …X‟.作为复选框输出Fieldcat-j ust = SPACE, \'R\', \'L\', \'C\'. 对齐方式Fieldcat-lzero = …X‟.输出前导零Fieldcat-no_sign = …X‟.输出抑制符号Fieldcat-no_zero = …X‟.为输出隐藏零Fieldcat-edit_mask = SPACE, mask.输出为mask的模式 Fieldcat-f ix_column = …X‟.固定列Fieldcat-do_sum = …X‟.总计列值总和Fieldcat-no_out = …X‟.列不输出Fieldcat-tech = …X‟.该字段为技术字段Fieldcat-outputlen = n 列的字符宽度为nFieldcat-decimals_out = n 能控制小数点的位数为nFieldcat-datatype = C,I,N…定义数据类型2. SORTdata: sortable type slis_t_sortinfo_alv with header line.it_sort = sortable[]属性(排序)Sortable-Fieldname 字段名U p 升序排列Dow n 降序排列Subtot3. Layoutdata: layout type slis_layout_alv .is_layout = layout属性 (用于定义ALV表单的相关格式、属性)inf o_f ieldname = 'LINE_COLOR'. 设置特殊行颜色(将LINE_COLOR增加到内表字段,写'CX10'到特殊行的LINE_COLOR, X为颜色值)colwidth_optimize = …X‟.优化列宽设置no_colhead = 'X'. 不显示列名no_vline = 'X'. 不显示列间竖线zebra = 'X' 可选行颜色,如果设置了,出现了间隔色带f2code = '&ETA'. 设置触发弹出详细信息窗口的功能码,这里是双击detail_initial_linesdetail_popup 是否弹出详细信息窗口detail_titlebar 设置弹出窗口的标题栏totals_texttotals_onlygroup_change_editheader_text4.按钮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'出口程序触发事件对应子程序:FOR M PF_STATUS_SET USING rt_extab TYPE slis_t_extab.FOR M user_command USING ucomm LIKE sy-ucomm self ield TYPE slis_self ield. 功能代码: 函数文本: 图标名称:&ETA 细节 ICON_SELECT_DETAIL&EB9 调用报告... ICON_TABLE_SETTINGS&REFRESH 刷新 ICON_REFR ESH&ALL 全部选择 ICON_SELECT_ALL&SAL 取消全选 ICON_DES ELECT_ALL&OUP 按升序排列 ICON_SOR T_UP&ODN 按降序排列 ICON_S ORT_DOWN&ILT 设置过滤器 ICON_FILTER&UMC 总计 ICON_SUM&SUM 小计... ICON_INTER MEDIATE_S UM&RNT_PR EV 打印预览 ICON_LAYOUT_CONTR OL&VEX CEL M icrosof t Excel ICON_XLS&AQW 字处理... ICON_W ORD_PR OCESSING%PC 本地文件 ... ICON_EXPORT%SL 邮件收件人 ICON_MAIL&AB C ABC分析 ICON_AB C&GRAPH 图形 ICON_GR APHICS&OL0更改布局... ICON_ALV_VAR IANTS&OAD 选择格式... ICON_ALV_VAR IANT_CHOOS E&AVE 保存格式... ICON_ALV_VAR IANT_S AVE&INF O 信息 ICON_INF OR MATION1. ALV表头设置i_callback_html_top_of_page = 'ALV_TOP_OF_PAGE'form top_of_page using cl_dd type ref to cl_dd_document.语法同HTML fomatALV_GRID介绍一.ALV介绍The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用.SAP提示: 在SAP的开发项目中,ALV GRID也可以作为修改和创建数据的一种工具,然而,目前这个功能只在实验计划中使用,还没有向客户发布.下面是一个ALV GRID的图片:它包括3大部分,工具栏,标题,用于显示数据的网格控制器.如果有必要,用户可以隐藏标题和工具栏.ALV家族包含3中ALV工具:简易的,两层ALV,分等级连续的列表和树形结构的ALV.二.ALV GRID CONTR OL (ALV网格控制器)ALV GRID CONTR OL使用了控制器技术以实现艺术性的屏幕显示,象所有的控制器一样,ALV GRID CONTR OL通过系统中的一个全局的类提供了方法,以响应它的动作.使用了AB AP的对象以后,列表是通过ALV的一个实例(INS TANCE)来显示的,程序员可以使用AB AP对象的事件管理.三.ALV GRID CONTR OL 实例ALV GRID实例的定义,参照CL_GUI_ALV_GRID类data ALV_GRID1 type ref to cl_gui_alv_grid.ALV GRID继承结构:ALV_GRID介绍(1)四、ALV GRID相关的几个控制结构1.字段目录 [Field catalog]字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTUR E LVC_S_FCAT)2R OW_POS ALV控制: 输出行 (内部使用)3COL_POS ALV 控制: 输出列列的位置,第几列,例如1,2,…..4FIELDNAME ALV 控制: 内部表字段的字段名称字段名称5TAB NAME LVC 标签名称表名,如果是内表,是16CURRENCY ALV 控制: 货币单位7CF IELDNAME ALV控制: 参考的当前单位的字段名称8QUANTITY ALV 控制: 计量单位9QFIELDNAME ALV 控制: 参考计量单位的字段名称10 IFIELDNAME ALV控制: 内部表字段的字段名称11 ROUND ALV控制: ROUND 值12 EXPONENT ALV 控制:流动表示的指数13 KEY ALV 控制: 关键字段关键字段,前面变蓝色14 KEY_SEL ALV控制: 可以被隐藏的关键列可以被隐藏的关键列15 ICON ALV 控制: 作为图标输出此列作为图标输出16 SYMB OL ALV 控制: 输出作为符号17 CHECKB OX ALV 控制: 作为复选框输出复选框输出18 JUST ALV控制: 对齐对齐方式:\'R\': right j ustif ied\'L\': lef t justified\'C\': centered19 LZER O ALV 控制: 输出前导零 X\'20 NO_SIGN ALV控制:输出抑制符号 X\',不输出符号21 NO_ZER O ALV 控制: 为输出隐藏零 X\',隐藏022 NO_CONVEX T ALV 控制: 不考虑输出的转换退出23 EDIT_MASK ALV 控制: 为输出编辑掩码格式24 EMPHASIZE ALV控制: 带有颜色的高亮列列的颜色25 FIX_COLUMN ALV 控制: 固定列26 DO_S UM ALV控制: 总计列值 X\',合计27 NO_SUM ALV控制: 没有总计列值 X\' ,没有合计28 NO_OUT ALV 控制: 列没有输出 X\' ,隐藏此列29 TECH ALV控制: 技术字段 X\'.也是隐藏,但是有点不一样30 OUTPUTLEN ALV 控制: 列的字符宽度输出的长度31 CONVEX IT 转换例程32 SELTEX T ALV 控制: 对话功能的列标识符33 TOOLTIP ALV 控制: 列抬头的工具提示34 ROLLNAME ALV 控制: F1帮助的数据元素35 DATATYPE AB AP字典中的数据类型 AB AP字典中的数据类型36 INTTYPE AB AP 数据类型(C,D,N,...) AB AP 数据类型(C,D,N,...)37 INTLEN以字节计的内部长度内容的长度38 LOWER CAS E允许/不允许小写字母 X\' 允许大小写39 REPTEX T 标题40 HIER_LEVEL ALV 控制: 内部使用41 REPR EP ALV控制: 价值是补充/补充接口的选择标准42 DOMNAME 定义域名43 SP_GR OUP 组代码44 HOTS POT ALV 控制: 单击敏感 X\',下面出现下划线,响应单击45 DFIELDNAME ALV控制: 数据库中列组的字段名称46 COL_ID ALV控制: 列 ID47 F4AVAILABL 字段有输入帮助吗 X\'.此列有搜索帮助48 AUTO_VALUE ALV控制: 自动复制值49 CHECKTABLE 表名50 VALEXI 固定值存在51 WEB_FIELD ALV 控制: 内部表字段的字段名称52 HREF_HNDL 自然数热点连接的句柄53 STYLE ALV 控制: 样式下面有例子会介绍,比如PUS HBUTTION54 STYLE2 ALV控制: 样式55 STYLE3 ALV控制: 样式56 STYLE4 ALV控制: 样式57 DRDN_HNDL 自然数下拉的句柄58 DRDN_FIELD ALV 控制: 内部表字段的字段名称下拉的字段59 NO_MER GING 字符字段长度 1相同的值不合并60 H_FTYPE ALV树控制: 功能类型 (总计,平均,最大.最小, ...)61 COL_OPT 可选列优化的条目62 NO_INIT_CH 字符字段长度 163 DRDN_ALIAS 字符字段长度 164 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 COLTEX T ALV 控制: 列标题列标题73 SCR TEX T_L 长字段标签74 SCR TEX T_M 中字段标签75 SCR TEX T_S 短字段标签76 COLDDICTX T ALV控制: 确定 DDIC 文本参考77 SELDDICTX T ALV 控制: 确定 DDIC文本参考78 TIPDDICTX T ALV 控制: 确定 DDIC文本参考79 EDIT ALV 控制: 准备输入输出状态.\'X\'可输入80 TECH_COL ALV控制: 内部使用81 TECH_FOR M ALV 控制: 内部使用82 TECH_COMP ALV 控制: 内部使用83 HIER_CPOS ALV 控制: 层次列位置84 H_COL_KEY 树控制: 列名称/项目名称85 H_SELECT标识是否可以选择树控制中的列86 DD_ROLL 数据元素 (语义域)87 DRAGDR OPID ALV控制: 拖&放处理拖放对象88 MAC字符字段长度 189 INDX_FIELD 自然数90 INDX_CFIEL 自然数91 INDX_QFIEL 自然数92 INDX_IFIEL 自然数93 INDX_R OUND 自然数94 INDX_DECML 自然数95 GET_S TYLE 字符字段长度 196 MARK 字符字段长度 1ALV_GRID介绍(2)2.布局控制[layout]布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.参照ALV的控制结构[LVC_S_LAYO],以后的例子我将详细介绍如何设置行颜色和列颜色. 详细的结构说明字段名描述 Value rangeCWIDTH_OPT 最优化宽度 SPACE, \'X\'SMALLTITLE小标题,如果设置了这个字段,则标题与列标题大小一样 SPACE, \'X\' GRID_TITLE标题,在网格和工具条之间最长70个字符NO_HEADERS 如果被设置,列标题隐藏 SPACE, \'X\'NO_HGRIDLN 隐藏水平线 SPACE, \'X\'NO_MER GING 禁用单元格合并 SPACE, \'X\'NO_ROWMARK 如果被设置,选择列在选择模式,为D和A的时候隐藏 SPACE, \'X\' NO_TOOLB AR 隐藏工具条 SPACE, \'X\'NO_VGRIDLN 隐藏垂直线 SPACE, \'X\'SEL_MODE 选择模式 SPACE, \'A\', \'B\', \'C\', \'D\'EX CP_CONDS 合计例外 SPACE, \'X\'EX CP_FNAME字段名称带有例外编码最长30个字符EX CP_LED 例外作为 LED SPACE, \'X\'EX CP_R OLLN例外文档的数据元素 SPACE, \'X\'CTAB_FNAME 带有复杂单元格颜色编码的字段名称最长30个字符INF O_FNAME 带有简单行彩色代码的字段名称最长30个字符ZEBR A 可选行颜色,如果设置了,出现了间隔色带 SPACE, \'X\'NO_TOTLINE 没有总计 SPACE, \'X\'NUMC_TOTAL 可以对NUMC字段进行合计 SPACE, \'X\'TOTALS_BEF 总计输出在第一行,小计在新的值之前 SPACE, \'X\'STYLEF NAME 设置单元格,比如PUS HBUTTON 最长30个字符ALV_GRID介绍(3)3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SOR T]过滤的参数控制请参考结构[LVC_S_FILT]这里不再一一解释,进入中文版本,里面应该也有解释的,虽然一些不是很清楚.五.编写简单的ALV程序.首先这里就不详细介绍DIALOG的用法了.OO的ALV GRID必须存在于一个容器当中,就是FUNCTION的ALV,其实也是一样的,底层也是使用CL_GUI_ALV_GR ID这个类的.首先ALV的显示需要有几个先决条件.1,字段目录,这个是必须的,如果没有这个参数,参考一个数据字典也是可以的,就是参数I_STR UCTUR E_NAME.2.存放数据的内表,最好内表的结构和字段目录是一致的,否则可能会出现一些无法预知的错误,当然你说我非要不一样,那也不一定会出现错误.我建议是最好一样的.这2个是必须的,布局的话,应该是可以不设置的,使用默认的就可以了.第一步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量.DATA:WCL_CONTAINER TYPE REF TO CL_GUI_CUS TOM_CONTAINER,WCL_ALV TYPE REF TO CL_GUI_ALV_GRID .*--- 存放字段目录的内表DATA gt_f ieldcat TYPE lvc_t_f cat .*--- 布局结构DATA gs_layout TYPE lvc_s_layo .*----声明需要显示的内表(以SFLIGHT为例)DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTUR E SFLIGHT .DATA END OF gt_list .第二步: 创建ALV这个对象,它的父组件是那个容器.在PBO中写入如下代码:PROCESS BEF ORE OUTPUT .创建DISPLAY_ALV的MODULE后,写下如下代码:MODULE display_alv OUTPUT .PERF OR M display_alv .ENDMODULE .在FOR M DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建: IF WCL_ALV IS INITIAL .CREATE OBJ ECT: WCL_CONTAINEREXPOR TINGCONTAINER_NAME = \'ALV_CON\'.CREATE OBJ ECT WCL_ALVEXPORTINGI_PARENT = WCL_CONTAINER."准备获取字段目录PERF OR M prepare_f ield_catalog CHANGING gt_f ieldcat ."设置布局PERF OR M prepare_layout CHANGING gs_layout ."显示ALVCALL METHOD gr_alvgrid->set_table_for_f irst_displayEXPOR TING* I_BUFFER_ACTIVE =* I_CONS IS TENCY_CHECK =* I_STRUCTUR E_NAME =* IS_VARIANT =* I_SAVE =* I_DEF AULT = \'X\'* IS_PRINT =* IT_SPECIAL_GR OUPS =* IT_TOOLB AR_EX CLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_list[]it_f ieldcatalog = gt_fieldcat* IT_S ORT =* IT_FILTER =EXCEPTIONSinvalid_parameter_combination = 1program_error = 2too_many_lines = 3OTHERS = 4 .ELSE.*----刷新ALVCALL METHOD gr_alvgrid->ref res h_table_display * EXPORTING* IS_STABLE =* I_SOF T_REFRES H =EXCEPTIONSfinished = 1OTHERS = 2 .IF sy-subrc <> 0.*--异常处理ENDIF.ENDIF .方法"set_table_f or_f irst_display"的参数说明------------------------------------------------------------------------------|I_BUFFER_ACTIVE | 如果方法调用是静态的,可以设置这个标记,| | 这表示,如果每次显示ALV都是相同的字段目录.| | 既然这样,那么字段目录会被放到一个特殊的缓存里, | | 这样加速了ALV的显示------------------------------------------------------------------------------|I_STRUCTURE_NAME | 输出数据参考的数据字典的结构名,例如\'SFLIGHT\'.| | 如果指定了这个参数,字段目录会自动生成,下面的参数| | IT_FIELDCATALOG不需要传值.------------------------------------------------------------------------------|IS_VARIANT | 决定布局显示的变式------------------------------------------------------------------------------|I_SAVE | 决定用户是否可以保存变式:| | 'X' 只能保存全局变式| | 'U' 只能保存特定变式| | 'A' 都可以保存| | SPACE 不可以保存变式------------------------------------------------------------------------------|I_DEF AULT | 决定用户是否可以定义默认的布局:| | 'X' 可以定义默认布局,这个参数是默认的| | SPACE 不可以定义默认布局------------------------------------------------------------------------------|IS_LAYOUT | 布局参数,传递布局控制的一些信息------------------------------------------------------------------------------|IS_PRINT | 后台打印属性的参数------------------------------------------------------------------------------|IT_SPECIAL_GR OUPS | 如果在字段目录中,一些字段通过SP_GR OUP被分组在一起. | | 我们就必须为这些组传递一个组的文本内表进去------------------------------------------------------------------------------|IT_TOOLB AR_EX CLUDING| 需要隐藏的标准的按钮的内表------------------------------------------------------------------------------|IT_HYPERLINK | 为每个句柄分配了超连接的内表,| | LVC_S_HYPE中的HREF存放了超连接的地址,| | HANDLE指定了句柄,使用这些句柄,你可以在GRID中使用超连接------------------------------------------------------------------------------|IT_ALV_GR APHICS | 比较复杂,没有用过,意思好象是可以在图表中显示ALV.------------------------------------------------------------------------------|IT_OUTTAB | 输出数据存放的内表,数据都是存放在这个内表里------------------------------------------------------------------------------|IT_FIELDCATALOG | 字段目录------------------------------------------------------------------------------|IT_S ORT | 排序的标准------------------------------------------------------------------------------|IT_FILTER | 过滤的标准------------------------------------------------------------------------------方法"REFRESH_TABLE_DIS PLAY"的参数说明------------------------------------------------------------------------------IS_STABLE 刷新的稳定性,有2个参数,一个是行,一个是列.如果设置了相应的值,那么对应的行,或者列,在刷新的时候,将会保持稳定,就是滚动条保持不动.------------------------------------------------------------------------------I_SOF T_REFRES H 这个参数只是在异常情况下被使用,如果设置了这个参数, 任何创建的合计,任何排序次序,任何为了显示数据而设置的过滤都将保持不变.这个是非常有意义的.例如:当然你没有修改数据内表里的数据而想刷新ALV,仅仅只是改变一下布局和字段目录.------------------------------------------------------------------------------第三步,获取要显示数据的字段目录.有两种方式.1.手动创建FOR M prepare_field_catalog CHANGING pt_f ieldcat TYPE lvc_t_f cat . DATA ls_f cat type lvc_s_f cat .ls_f cat-f ieldname = \'CARR ID\' .ls_f cat-inttype = \'C\' .ls_f cat-outputlen = \'3\' .ls_f cat-coltext = \'Carrier ID\' .ls_f cat-seltext = \'Carrier ID\' .APPEND ls_f cat to pt_f ieldcat .CLEAR ls_f cat .ls_f cat-f ieldname = \'CONNID\' .ls_f cat-ref_table = \'SFLIGHT\' .ls_f cat-ref_table = \'CONNID\' .ls_f cat-outputlen = \'3\' .ls_f cat-coltext = \'Connection ID\' .ls_f cat-seltext = \'Connection ID\' .APPEND ls_f cat to pt_f ieldcat .2.半自动的创建FOR M prepare_field_catalog CHANGING pt_f ieldcat TYPE lvc_t_f cat . DATA ls_f cat type lvc_s_f cat .CALL FUNCTION \'LVC_FIELDCATALOG_MERGE\'EXPOR TINGi_structure_name = \'SFLIGHT\'CHANGINGct_fieldcat = pt_fieldcat[]EX CEPTIONSinconsistent_interf ace = 1program_error = 2OTHERS = 3.IF sy-subrc <> 0.*--Exception handlingENDIF.LOOP AT pt_fieldcat INTO ls_f cat .CAS E pt_f ieldcat-fieldname .WHEN \'CARRID\' .ls_f cat-outpulen = \'10\' .ls_f cat-coltext = \'Airline Carrier ID\' .MODIFY pt_fieldcat FROM ls_f cat .WHEN \'PAYMENTSUM\' .ls_f cat-no_out = \'X\' .MODIFY pt_fieldcat FROM ls_f cat .ENDCAS E .ENDF ORM .第四步,设置布局FOR M prepare_layout CHANGING ps_layout TYPE lvc_s_layo.ps_layout-zebra = \'X\' .ps_layout-grid_title = \'Flights\' .ps_layout-smalltitle = \'X\' .ENDF ORM. " prepare_layout第五步,排除不需要的标准按钮(可选,这个是第一种方法,还有另外一种,在添加自定义的按钮的时候介绍) 在你的ALV上,如果你想排除一些你不想要的标准按钮,你可以把需要排除的按钮填入到表UI_F UNCTIONS中,然后传给 set_table_f or_first_display方法的参数"IT_TOOLB AR_EX CLUDING".这些按钮的功能码一般都可以通过查看类 cl_gui_alv_grid的常量属性中获取到,或者自己加个断点,在after_user_command事件中.如果你要隐藏全部的工具条,你可以把layout中的no_toolbar设置为"X".FOR M exclude_tb_functions CHANGING pt_exclude TYPE ui_functions .DATA ls_exclude TYPE ui_func.ls_exclude = cl_gui_alv_grid=>mc_f c_maximum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_minimum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_subtot .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_f c_average .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_subtot .ENDF ORM .按照上面的步骤,一个ALV的DEMO基本可以创建了.下面我们将讲述一些功能.功能一:在第一次显示以后,修改字段目录和布局.在运行的时候,很有可能需要在显示之后,需要设置一个新的布局或者字段目录.有下面这些方法去实现. 字段目录: get_frontend_f ieldcatalogs et_f rontend_fieldcatalog布局: get_frontend_layouts et_f rontend_layout使用这些方法,你在执行的任何时候,可以获取这些内容,然后修改他们.DATA ls_f cat TYPE lvc_s_f cat .DATA lt_f cat TYPE lvc_t_f cat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_f rontend_fieldcatalogIMPORTINGet_f ieldcatalog = lt_f cat[] .LOOP AT lt_f cat INTO ls_f cat .IF ls_f cat-f ieldname = \'PAYMENTS UM\' .ls_f cat-no_out = s pace .MODIF Y lt_f cat FROM ls_f cat .ENDIF .ENDLOOP .CALL METHOD gr_alvgrid->set_f rontend_fieldcatalogEXPOR TINGit_f ieldcatalog = lt_f cat[] .CALL METHOD gr_alvgrid->get_f rontend_layoutIMPORTINGes_layout = ls_layout .ls_layout-grid_title = \'Flights (w ith Payment Sums)\' .CALL METHOD gr_alvgrid->set_f rontend_layoutEXPOR TINGis_layout = ls_layout .功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构LVC_T_S OR T创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_f or_f irst_display这个方法的IT_S OR T参数来初始化一个排序.FOR M prepare_sort_table CHANGING pt_sort TYPE lvc_t_sort .DATA ls_sort TYPE lvc_s_sort .ls_sort-spos = \'1\' .ls_sort-f ieldname = \'CARRID\' .ls_sort-up = \'X\' . "A to Zls_sort-down = space .APPEND ls_sort TO pt_sort .ls_sort-spos = \'2\' .ls_sort-f ieldname = \'SEATS OCC\' .ls_sort-up = space .ls_sort-down = \'X\' . "Z to AAPPEND ls_sort TO pt_sort .ENDF ORM. " prepare_sort_table这有2点特别的说明:1.如果这边排序的字段名,不存在于字段目录中,那将出现DUMP.2.排序以后,垂直的网格中,如果出现相同的内容,就会合并,如果要避免,请在布局中设置"no_merging"为"X" .你可以通过使用方法“get_sort_c riteria” 和“set_sort_criteria”来获取和设置排序的标准.功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FILT"创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法"SET_TABLE_FOR_FIRS T_DIS PLAY"中的参数"IT_FILTER" FOR M prepare_filter_table CHANGING pt_f ilt TYPE lvc_t_f ilt .DATA ls_f ilt TYPE lvc_s_filt .ls_f ilt-fieldname = \'FLDATE\' .ls_f ilt-sign = \'E\' .ls_f ilt-option = \'BT\' .ls_f ilt-low = \'20030101\' .ls_f ilt-high = \'20031231\' .APPEND ls_f ilt TO pt_f ilt .ENDF ORM. " preparef iltertable我们可以使用"get_f ilter_criteria" 和"set_f ilter_criteria"来获取过滤条件和设置过滤条件.功能四:选择方式有时候,我们需要选择一些单元格,行或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.值模式可能的选择注释SPACE 等同于B 参考B 默认设置\'A\' 行和列的选择,无法选择单元格多行,多列用户可以使用最左边的选择按钮来选择多行\'B\' 单选,不可以多选行,不可以多选单元格多行,多列\'C\' 多选,可以多选行,不可以多选单元格多行,多列\'D\' 单元格的选择,可以多选单元格多行,多列,任何单元格多选用户可以使用最左边的选择按钮来选择多行注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择方式的设置的.2.设置了选择方式以后,我们可以使用很多方法来获取用户的选择.比如"GET_S ELECTED_CELLS","GET_SELECTED_CELLS_ID","GET_S ELECTED_ROWS","GET_SELECTED_COLUMNS"3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PB O中,使用对应的SET方法来恢复这些选择.功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cxyz---Color || || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第一位,第二位代表是颜色编码(1到7),第三位是加强的设置,第四位是相反,个人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:x 颜色主要使用在1Gray-blue headers2Light gray List bodies3yellow totals4Blue-green Key columns5green Positive threshold value6red Negative threshold value7orange Control levelsA)设置列的颜色.我们可以通过字段目录的"emphasize"控制字段来控制某列的颜色.这个字段同样是4位的CHAR型,传入上述的颜色编码.例如:LS_FCAT-EMPHAS IZE = \'C701\'.如果这列被设置为关键列,就是 LS_FCAT-K EY = \'X\' ,那么颜色设置就不会起作用.请注意,自动产生的字段目录中,KEY的设置是自动获取的.B)设置行的颜色为某行设置颜色,是有点复杂的,我们需要在要显示的数据内表中增加一个字段,这个字段不需要在字段目录中存在.同样,这个字段也是4位的CHAR型,符合颜色编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA END OF gt_list .很明显,填入颜色编码以后,ALV怎么知道它是我们用来设置颜色的呢,在布局中,有个控制字段"INF O_FNAME",我们可以设置这个字段来告诉ALV,我们的颜色字段是哪个.ps_layout-inf o_fname = \'ROWCOLOR\'.请注意,这个字段随便你起名字,但是记住,一定是数据内表里的字段,而且这边设置的时候一定要大写.你可以在任何时候设置行的颜色,只需要去修改内表里的这个字段的值,但是记得,一定要刷新以后才起作用.C)设置单元格的颜色设置单元格和设置行的颜色,本质上没有什么大的区别,但是定位单元格需要2个参数.我们需要在数据内表中插入一个表类型的字段,这样我们的数据内表就变成了DEEP结构了,不过ALV是可以处理的.不需要担心.插入的这个表类型的类型为"LVC_T_S COL".里面有3个参数:FNAME告诉我们你需要设置的是哪个字段,如果为空,然后直接在COLOR中设置颜色,就是整行设置为这个颜色.如果具体到某个单元格,必须指定是哪个字段.COLOR字段是用来设置颜色的.NOK EYCOL字段比较关键了.设置为关键列的一些字段,我们的颜色设置可能被覆盖.通过这个字段的设置,可以避免被关键列覆盖.同样,ALV在布局中有个字段"CTAB_FNAME"告诉我们,数据内表中,哪个字段是用来设置单元格的颜色的.DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA END OF gt_list .DATA ls_cellcolor TYPE lvc_s_scol ....READ TABLE gt_list INDEX 5 .ls_cellcolor-fname = \'SEATS OCC\' .ls_cellcolor-color-col = \'7\' .ls_cellcolor-color-int = \'1\' .APPEND ls_cellcolor TO gt_list-cellcolors .MODIF Y gt_list INDEX 5 .注意:颜色设置中有优先级顺序,他们是单元格--->行--->列.功能六:插入超链接插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为"LVC_T_HYPE" ,句柄是一个INT4类型的字段,我们需要在数据显示的内表中,加入这样的字段,来告诉ALV,我们的字段指定的句柄,从而找到对应的超级链接.在字段目录中,WEB_FIELD是用来指定对应的句柄名的. 下面举个例子来说明,我们要为字段CARRID,CONNID建立超级链接:首先,内表定义中,我们加入2个句柄字段:DATA BEGIN OF gt_list OCCURS 0 .INCLUDE STRUCTURE SFLIGHT .DATA row color(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA carrid_handle TYPE int4 .DATA connid_handle TYPE int4 .DATA END OF gt_list .第二: 建立一个超级链接内表,里面存放句柄所对应的超级链接.创建的时候注意,它参考的表类型,一定是"LVC_T_HYPE". FOR M prepare_hyperlinks_table CHANGING pt_hype TYPE lvc_t_hype .DATA ls_hype TYPE lvc_s_hype .ls_hype-handle = \'1\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'2\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'3\' .ls_hype-href = \'http://www.c /carrids/car1\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'4\' .ls_hype-href = \'http://www.c /connids/con11\' .APPEND ls_hype TO pt_hype .ls_hype-handle = \'5\' .ls_hype-href = \'http://www.c /connids/con12\'APPEND ls_hype TO pt_hype ... ..ENDF ORM .第三.通过字段目录FIELDCATLOG来指定相应的句柄字段.对于CARRID的field catalogLs_fieldcat-w eb_field = …CARRID_HANDLE‟.对于CONNID的field catalogLs_fieldcat-w eb_field = …CONNID_HANDLE‟.在方法"SET_TABLE_F OR_FIRST_DISPLAY"中把句柄内表传给参数it_hyperlink。

相关文档
最新文档