ALV TABLE :ALV的聚合,排序,过滤
abap 中快速调用alv显示的方法
abap 中快速调用alv显示的方法全文共四篇示例,供读者参考第一篇示例:在ABAP开发中,经常需要通过ALV(Application List Viewer)显示数据表格,以便更直观、友好地展示数据给用户。
有时候我们需要在程序中快速调用ALV显示数据,而不需要太多繁琐的操作。
本文将介绍一种快速调用ALV显示数据的方法,帮助开发者更高效地展示数据。
在ABAP中,我们可以使用几种方法来显示ALV,比如使用函数模块、类库等。
但是如果我们只需要快速显示一个简单的表格,并且不想在程序中定义太多冗余的内容,可以使用以下方法来快速调用ALV显示数据。
我们需要在程序中定义一个内表和一个字段符号。
内表用来存储我们需要展示的数据,字段符号用来代表内表中的字段。
```ABAPDATA: lt_data TYPE TABLE OF mara,fs_field TYPE ANY.```接下来,我们需要获取数据并填充到内表中。
这里以从表MARA 中获取数据为例,我们可以使用SELECT语句获取数据并填充到内表中。
然后,我们可以调用函数模块REUSE_ALV_GRID_DISPLAY来显示ALV表格。
这个函数模块会自动创建一个ALV显示表格,并展示我们所填充的数据。
这样,我们就可以快速调用ALV显示数据了。
值得注意的是,在调用REUSE_ALV_GRID_DISPLAY函数模块前,我们需要确保内表lt_data已经填充了数据,并且字段符号fs_field已经对应了内表中的字段。
通过这种方法,我们可以快速、简便地在ABAP程序中调用ALV 显示数据。
当我们只需要展示一个简单的表格时,这种方法可以帮助我们避免繁琐的定义和配置,提高开发效率。
快速调用ALV显示数据的方法虽然简单,但在实际开发中却很实用。
当我们需要快速展示一个简单的表格时,善用这种方法可以让我们更专注于业务逻辑的实现,提高开发效率,也给用户提供更好的交互体验。
ABAP开发者可以根据自己的实际需求,选择适合的方法来显示ALV表格,提高开发效率,为用户提供更好的体验。
ABAP ALV详解
ALV GRID参考文档SAP HELP对ALV的定义如下:The ALV grid control is a flexible tool for displaying lists. The tool provides common list operations as generic functions and can be enhanced by self-defined options。
ALV Grid控件用来创建非层次的友好的交互式报表。
作为一个控件,他被安装在本地机的客户端上。
ALV Grid控件提供了典型的常用功能,比如排序,筛选和总计等。
同时他也提供了自开发功能的接口。
它提供了大量与excel和水晶报表的接口。
类CL_GUI_GRID用来实现ALV GRID控件的各种功能。
还可以使用:REUSE_ALV….这些功能模块,来实现ALV报表。
当我们想通过ALV来实现报表时,我们通常需要准备一下几个部分:1)List data;就是你要显示的内表。
除排序功能之外,ALV GRID的控件只是读取所要显示的内表中的内容。
然而,排序将会改表内表的状态。
所要显示的内表可以包含任何flat type的数据。
如果要显示deep type的数据,那可能就要设定ALV GRID的某些特定功能。
2)Field Catalog: 使用另外一个内表来定义ALV报表的每一个字段的显示方式。
Fieldcatalog可以通过三种方式来实现:自动生成,半自动和手动生成。
这个内表的类型必须是LVC_T_FCAT3)Layout Structure: 我们可以通过这个结构来设置ALV的显示格式。
用这个结构我们可以用来设置ALV的常用选项,对GRID控件的配置,汇总选项已经颜色等。
这个结构的类型必须是LVC_S_LAYO4)Event Handler: 如果我们想在alv grid中触发时间,可以通过事件处理类来实现,必须注册一个事件处理类的实例来处理alv grid的事件。
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。
sap alv 单元格格式
sap alv 单元格格式
SAP ALV(Automatic List Viewer)是一种用于显示数据网格的报表工具,具有汇总、排序和筛选等功能。
关于SAP ALV的单元格格式,可以按照以下步骤进行设置:
1. 在ALV表格中,选择要设置格式的单元格。
2. 在属性列中,找到“单元格属性”选项,并单击它。
3. 在弹出的对话框中,选择“显示格式”选项卡。
4. 在“显示格式”选项卡中,可以设置单元格的格式,例如数字、货币、日期等。
还可以设置小数位数、千位分隔符等。
5. 单击“确定”按钮以保存设置。
除了设置单元格格式外,还可以使用ALV的其他功能,例如排序、筛选和汇总等。
这些功能可以帮助您更好地组织和呈现数据。
alv 排序单元格不合并 -回复
alv 排序单元格不合并-回复主题:[alv 排序单元格不合并]在SAP系统中,ALV(ABAP List Viewer)是一种用于在SAP屏幕上显示和管理数据的强大工具。
它允许用户以表格形式呈现数据,并提供各种功能,如排序、筛选和合并单元格。
然而,有时候我们可能遇到一种问题,即排序单元格后,单元格不再合并。
本文将一步一步地解答这个问题,并讨论可能的解决方案。
第一步:了解ALV单元格合并功能在开始解决问题之前,我们先了解一下ALV单元格合并功能是如何工作的。
在ALV中,当相邻的单元格具有相同的值时,它们可能会合并成一个大的单元格。
这样可以提高数据的可读性和整洁度。
然而,当我们对表格进行排序操作后,单元格的合并功能可能会受到影响。
第二步:复现问题在解决问题之前,我们需要先复现这个问题,以确认它确实存在。
为此,我们可以创建一个简单的ALV表格,并添加一些需要排序的数据。
然后,通过排序功能对表格进行排序。
第三步:查看排序后的表格一旦完成排序,我们将查看排序后的表格,并检查合并单元格是否失效。
如果发现单元格不再合并,我们可以肯定地说这个问题确实存在。
第四步:查阅相关文档和资源在解决问题之前,我们需要查阅SAP提供的相关文档和资源,以获取更多关于ALV单元格合并功能的信息。
这些资源可以包括官方文档、SAP社区和开发者论坛等。
通过阅读这些资源,我们可以了解该问题的原因和可能的解决方法。
第五步:尝试解决问题现在我们了解了问题的背景和原因,可以尝试一些解决方法。
以下是一些可能的解决方法:1. 禁用排序功能:如果这个问题对你的应用来说并不重要,并且合并单元格对数据的可读性影响不大,你可以选择禁用排序功能。
这样一来,单元格将保持合并状态,无论是否进行排序操作。
2. 自定义合并单元格逻辑:如果你需要在排序后保持合并单元格的功能,你可以考虑自定义合并单元格的逻辑。
通过编写自定义代码,你可以实现在排序后保持单元格合并的效果。
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。
alv 抓取用户变式的方法
alv 抓取用户变式的方法
ALV (ABAP List Viewer) 是一个强大的工具,用于显示 ALV 表格。
要抓取用户变式,你可以使用 ALV 的内建功能。
以下是如何抓取用户变式的简单步骤:
1. 定义 ALV 表格:
首先,你需要定义一个 ALV 表格,该表格的源是一个表或内表。
2. 设置 ALV 属性:
在定义 ALV 表格后,你可以设置其属性以决定如何显示数据。
例如,你可以设置列的宽度、是否显示某些列等。
3. 使用用户变式:
在 ALV 的属性中,有一个名为 `USER_DEF_SORT` 的属性。
你可以使用这个属性来定义一个用户变式,该变式决定了如何对数据进行排序。
4. 运行 ALV:
当你运行 ALV 时,它会显示数据,并根据你在 `USER_DEF_SORT` 中定义的排序规则进行排序。
5. 保存用户变式:
如果你希望保存当前的排序或过滤条件,你可以使用 `SAVE_VIEW_AS` 方法来保存它为一个用户变式。
之后,你可以在其他地方加载和使用这个用户变式。
6. 使用已保存的用户变式:
要使用已保存的用户变式,你可以在 `USER_DEF_SORT` 中设置 `VALUE` 属性为该变式的名称。
然后,当你运行 ALV 时,它会使用该变式定义的排序和过滤条件。
总之,要抓取 ALV 中的用户变式,关键是使用 `USER_DEF_SORT` 属性来定义排序规则,并使用 `SAVE_VIEW_AS` 方法来保存它为一个用户变式。
之后,你可以在其他地方加载和使用这个用户变式。
SAP_ABAP_OO_实现_CL_SALV_TABLE
SAP_ABAP_OO_实现_CL_SALV_TABLEOO实现ALV⼀、最简单的ALV显⽰以前都是通过函数“REUSE_ALV_GRID_DISPLAY”来显⽰列表,这种⽅式是⾯向过程的,现在有另外⼀种⾯向对象化的⽅式来显⽰列表,函数REUSE_ALV_GRI D_DISPLAY可以做到的它也能够做到。
它主要是通过⼀个类CL_SALV_TABLE来实现的.下⾯让我们来实现最简单的ALV列表。
1取得要显⽰的数据。
2.调⽤类CL_SALV_TABLE的静态⽅法Factory()创建类的实例。
3.取得实例之后再调⽤⽅法Display()显⽰列表.处理过程完成,最后让我们看⼀下显⽰结果。
下⾯是报表的所有源代码:关于ALV的最全⽂档可以参考SAP Help/doc/67f98ad53186bceb19e8bb3a.html /saphelp_nw70/helpdata/EN/5e/88d440e14f8431e10 000000a1550b0/content.htm⼆、ALV显⽰的三种形式⼀般的ALV有三种显⽰形式,分别为⼀、普通的List⼆、全屏的Grid三、在⾃定义屏幕的显⽰的Grid跟以往实现这三种ALV显⽰⽅式相⽐,以往的三种显⽰⽅式分别是调⽤不同的Function和Class,实现⽅式复杂。
现在这三种显⽰⽅式可以通过⼀个类(CL _SALV_TABLE)来实现,⽽且通过这个类和它的⼦类可以更加容易的实现ALV的功能,⽐如:排序,总计,过滤,页眉页脚,单击双击事件等。
下⾯让我们⼀步⼀步地来实现这三种显⽰形式。
1.⾸先我们先创建选择屏幕,屏幕有三个选项,三个选项分别为三种显⽰⽅式。
2取得要显⽰的数据。
3.判断选择屏幕的选项创建不同的实例。
4.当⽤户选择第⼀个选项,列表输出为全屏的⽹格列表,执⾏⽅法alv_ful l( )。
5.当⽤户选择第⼆个选项,列表输出为普通的列表,执⾏⽅法alv_list( ). alv_list⽅法跟alv_full⽅法不同的是在创建实例的时候多了⼀个选项list_ display = ‘X’.6.当⽤户选择第三个选项,列表在⾃定义屏幕上输出⽹格列表,执⾏⽅法a lv_grid( ).⽅法alv_grid()调⽤了屏幕100。
前端框架中的表格排序与筛选技巧
前端框架中的表格排序与筛选技巧在前端开发中,表格是页面常见的数据展示方式之一。
为了让用户更方便地浏览和查找数据,表格的排序和筛选功能非常重要。
在使用前端框架进行开发时,可以借助框架提供的 API 和组件,快速实现表格的排序和筛选功能。
本文将介绍几种常用的前端框架中的表格排序与筛选技巧。
一、排序技巧1. 列头点击排序:在表格中,通常会给列头添加一个排序的图标,表示该列是否处于升序或降序的状态。
当用户点击列头时,可以通过监听事件,在前端框架中实现表格数据的排序。
具体实现方式如下:```// HTML<th @click="sortBy('columnName')">Column Name<i v-show="sortKey === 'columnName'" :class="sortOrders[columnName] === 1 ? 'fa fa-caret-down' : 'fa fa-caret-up'"></i></th>// JavaScriptsortBy(columnName) {this.sortKey = columnName;this.sortOrders[columnName] = this.sortOrders[columnName] * -1;this.tableData.sort((a, b) => {return a[columnName].localeCompare(b[columnName]) *this.sortOrders[columnName];});}```以上代码在点击列头时,通过改变 `sortOrders` 数组中对应字段的值实现升序和降序的切换,然后使用 `Array` 的 `sort` 方法对表格数据进行排序。
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的用法。
FM实现ALV Table 七:汇总,分类汇总,排序,过滤
Function实现ALV Table七:汇总,分类汇总,排序,过滤ALV标准功能汇总,分类汇总,排序,过滤这些功能除了可以直接使用它的标准功能按钮之外,你也可以在程序里设定,让ALV列表第一次显示出来就已经使用了这些功能。
用REUSE_ALV_GRID_DISPLAY实现的ALV不能在程序设定输出字段的平均值,最小值,最大值等标准功能。
用OO方式实现ALV输出的就可以,请参考/lhx20/archive/2008/08/26/2833234.aspx一、排序排序用到类型slis_t_sortinfo_alv,按条件把过滤的字段和规则设置好,添加到一个参考slis_t_sortinfo_alv类型的内表,在调用Function的时候指导内表赋给it_sort参数二、过滤过滤用到类型slis_t_filter_alv,按条件把排序的字段和规则设置好,添加到一个参考slis_t_filter_alv类型的内表,在调用Function的时候把内表的值赋给it_fitler参数三、分类汇总分类汇总是汇总和排序两个功能来进行分类和汇总的。
按照排序的字段的值进行分类,对已经汇总的字段进行分类汇总。
在设置排序的时候设置类型slis_t_sortinfo_alv -subtot =‘X’就可以了。
四、汇总汇总是设置要汇总的字段的Fieldcat属性,设置slis_t_fieldcat_alv-do_sum = ‘X’。
下面是源代码TYPE-POOLS slis.TYPES ty_tab_spfli TYPE spfli OCCURS 0.START-OF-SELECTION.PERFORM f_display.*&---------------------------------------------------------------------* *& Form f_getdata*&---------------------------------------------------------------------* * text*----------------------------------------------------------------------* * -->PT_SPFLI text*----------------------------------------------------------------------* FORM f_getdata TABLES pt_spfli TYPE ty_tab_spfli.SELECT * FROM spfli INTO TABLE pt_spfli.ENDFORM. "f_getdata*&---------------------------------------------------------------------* *& Form f_display*&---------------------------------------------------------------------* * text*----------------------------------------------------------------------* FORM f_display.DATA: lt_spfli TYPE ty_tab_spfli,lt_filter TYPE slis_t_filter_alv,lt_sort TYPE slis_t_sortinfo_alv,lt_fieldcat TYPE slis_t_fieldcat_alv.PERFORM f_getdata TABLES lt_spfli.PERFORM f_filter_build TABLES lt_filter.PERFORM f_sort_build TABLES lt_sort.PERFORM f_fieldcat CHANGING lt_fieldcat.CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'EXPORTINGi_callback_program = sy-repidit_fieldcat = lt_fieldcatit_filter = lt_filterit_sort = lt_sortTABLESt_outtab = lt_spfli.ENDFORM. "f_display*&---------------------------------------------------------------------**& Form f_fieldcat*&---------------------------------------------------------------------** text*----------------------------------------------------------------------** -->PT_FIELDCAT text*----------------------------------------------------------------------* FORM f_fieldcat CHANGING pt_fieldcat TYPE slis_t_fieldcat_alv.FIELD-SYMBOLS <fs_fieldcat> LIKE LINE OF pt_fieldcat.CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'EXPORTINGi_structure_name = 'SPFLI'CHANGINGct_fieldcat = pt_fieldcatEXCEPTIONSinconsistent_interface = 1program_error = 2other = 3.LOOP AT pt_fieldcat ASSIGNING <fs_fieldcat> WHERE fieldname = 'DISTANCE'. <fs_fieldcat>-do_sum = 'X'.ENDLOOP.ENDFORM. "f_fieldcat*&---------------------------------------------------------------------**& Form f_filter_build*&---------------------------------------------------------------------** text*----------------------------------------------------------------------** -->PT_FILTER text*----------------------------------------------------------------------* FORM f_filter_build TABLES pt_filter TYPE slis_t_filter_alv.DATA lwa_filter LIKE LINE OF pt_filter.lwa_filter-fieldname = 'DISTANCE'.lwa_filter-sign0 = 'E'.lwa_filter-optio = 'EQ'.lwa_filter-valut = 'MI '.APPEND lwa_filter TO pt_filter.ENDFORM. "f_filter_build*&---------------------------------------------------------------------* *& Form f_sort_build*&---------------------------------------------------------------------* * text*----------------------------------------------------------------------* * -->PT_SORT text*----------------------------------------------------------------------* FORM f_sort_build TABLES pt_sort TYPE slis_t_sortinfo_alv.DATA lwa_sort LIKE LINE OF pt_sort.lwa_sort-fieldname = 'CARRID'.lwa_sort-up = 'X'.lwa_sort-subtot = 'X'.APPEND lwa_sort TO pt_sort.ENDFORM. "f_sort_build。
element-plus el-table-v2 实现原理
Element Plus 的el-table-v2 组件是基于Vue.js 和Element UI 组件库开发的,主要实现了表格的渲染、分页、排序、筛选、编辑、合并等功能。
下面简单介绍el-table-v2 组件的实现原理:
1. 数据源:el-table-v2 组件需要从外部获取数据源,数据可以是数组、对象、接口等形式。
2. 渲染表格:el-table-v2 组件根据数据源渲染表格,通过v-for 指令循环遍历数据,生成表格的行和列。
3. 分页:el-table-v2 组件支持分页功能,通过计算总页数和当前页数,动态生成分页器,并在点击页码时触发数据的重新渲染。
4. 排序:el-table-v2 组件支持列的排序功能,通过点击表头上的排序按钮,触发数据的重新排序,并在表头上显示当前排序的状态。
5. 筛选:el-table-v2 组件支持列的筛选功能,通过点击表头上的筛选按钮,弹出筛选框,用户可以选择筛选条件,触发数据的重新渲染。
6. 编辑:el-table-v2 组件支持单元格的编辑功能,通过点击单元格,触发编辑状态,并在单元格内显示编辑框,用户可以对单元格进行编辑,完成后保存数据。
7. 合并:el-table-v2 组件支持单元格的合并功能,通过设置rowspan 和colspan 属性,实现单元格的合并。
总之,el-table-v2 组件通过数据源、渲染表格、分页、排序、筛选、编辑、合并等多种方式,实现了强大的表格功能,为开发者提供了便利和灵活性。
ALV常用参数的详细描述
ALV常用参数的详细描述调用功能模块:CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'EXPORTINGi_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[] 排序设置TABLESt_outtab = ig_outEXCEPTIONSprogram_error = 1OTHERS = 2.常用属性:(赋值’’中内容必须为大写)1.Fieldcatdata: fieldcat type slis_t_fieldcat_alv with 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)颜色同format)Fieldcat-hotspot = ‘X’. 作为热点显示可触发鼠标触发事件Fieldcat-currency = ‘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-just = SPACE, 'R', 'L', 'C'. 对齐方式Fieldcat-lzero = ‘X’. 输出前导零Fieldcat-no_sign = ‘X’. 输出抑制符号Fieldcat-no_zero = ‘X’. 为输出隐藏零Fieldcat-edit_mask = SPACE, mask.. 输出为mask的模式Fieldcat-fix_column = ‘X’. 固定列Fieldcat-do_sum = ‘X’. 总计列值总和Fieldcat-no_out = ‘X’. 列不输出Fieldcat-tech = ‘X’. 该字段为技术字段Fieldcat-outputlen = n 列的字符宽度为nFieldcat-decimals_out = n 能控制小数点的位数为n Fieldcat-datatype = C,I,N…定义数据类型2.SORTdata: sortable type slis_t_sortinfo_alv with header line.it_sort = sortable[]属性(排序)Sortable-Fieldname 字段名Up 升序排列Down 降序排列Subtot3.Layoutdata: layout type slis_layout_alv .is_layout = layout属性 (用于定义ALV表单的相关格式、属性)info_fieldname = 'LINE_COLOR'. 设置特殊行颜色(将LINE_COLOR增加到内表字段,写'CX10'到特殊行的LINE_COLOR, X为颜色值)colwidth_optimize = ‘X’. 优化列宽设置no_colhead = 'X'. 不显示列名no_vline= 'X'. 不显示列间竖线zebraf2code = '&ETA'. 设置触发弹出详细信息窗口的功能码,这里是双击no_vline 这个用来设置列间隔线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'出口程序触发事件对应子程序: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&OL0 更改布局... ICON_ALV_VARIANTS&OAD 选择格式... ICON_ALV_VARIANT_CHOOSE&AVE 保存格式... ICON_ALV_VARIANT_SAVE&INFO 信息ICON_INFORMATION1.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 CONTROL (ALV网格控制器)ALV GRID CONTROL使用了控制器技术以实现艺术性的屏幕显示,象所有的控制器一样,ALV GRID CONTR OL通过系统中的一个全局的类提供了方法,以响应它的动作.使用了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)四、ALV GRID相关的几个控制结构1.字段目录[Field catalog]字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等.常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTURE LVC_S_FCAT)2 ROW_POS ALV 控制: 输出行 (内部使用)3 COL_POS ALV 控制: 输出列列的位置,第几列,例如1,2,…..4 FIELDNAME ALV 控制: 内部表字段的字段名称字段名称5 TABNAME LVC 标签名称表名,如果是内表,是16 CURRENCY ALV 控制: 货币单位7 CFIELDNAME ALV 控制: 参考的当前单位的字段名称8 QUANTI TY 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': centered19 LZERO ALV 控制: 输出前导零 X'20 NO_SIGN ALV 控制:输出抑制符号 X',不输出符号21 NO_ZERO ALV 控制: 为输出隐藏零 X',隐藏022 NO_CONVEXT ALV 控制: 不考虑输出的转换退出23 EDI T_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 控制: 列ID47 F4AVAILABL 字段有输入帮助吗 X'.此列有搜索帮助48 AUTO_VALUE ALV 控制: 自动复制值49 CHECKTABLE 表名50 VALEXI 固定值存在51 WEB_FIELD ALV 控制: 内部表字段的字段名称52 HREF_HNDL 自然数热点连接的句柄53 STYLE ALV 控制: 样式下面有例子会介绍,比如PUSHBUTTION54 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 字符字段长度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 COLTEXT ALV 控制: 列标题列标题73 SCR TEXT_L 长字段标签74 SCR TEXT_M 中字段标签75 SCR TEXT_S 短字段标签76 COLDDICTXT ALV 控制: 确定DDIC 文本参考77 SELDDICTXT ALV 控制: 确定DDIC 文本参考78 TIPDDICTXT ALV 控制: 确定DDIC 文本参考79 EDI T 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 字符字段长度189 INDX_FIELD 自然数90 INDX_CFIEL 自然数91 INDX_QFIEL 自然数92 INDX_IFIEL 自然数93 INDX_ROUND 自然数94 INDX_DECML 自然数95 GET_STYLE 字符字段长度196 MARK 字符字段长度1ALV_GRID介绍二(3)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_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个字符ALV_GRID介绍二(4)3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SOR T]过滤的参数控制请参考结构[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_displayEXPOR TING* 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_SOR T =* 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_BUFFER_ACTI VE 如果方法调用是静态的,可以设置这个标记,这表示,如果每次显示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_GR OUPS 如果在字段目录中,一些字段通过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,仅仅只是改变一下布局和字段目录.ALV_GRID介绍二(5)第三步,获取要显示数据的字段目录.有两种方式.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'EXPOR TINGi_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 .ALV_GRID介绍二(6)第四步,设置布局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_GRID介绍二(7)按照上面的步骤,一个ALV的DEMO基本可以创建了.下面我们将讲述一些功能.功能一:在第一次显示以后,修改字段目录和布局.在运行的时候,很有可能需要在显示之后,需要设置一个新的布局或者字段目录.有下面这些方法去实现.字段目录: get_frontend_fieldcatalogset_frontend_fieldcatalog布局: get_frontend_layoutset_frontend_layout使用这些方法,你在执行的任何时候,可以获取这些内容,然后修改他们.DATA ls_fcat TYPE lvc_s_fcat .DATA l t_fcat TYPE lvc_t_fcat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_frontend_fieldcatalogIMPORTINGet_fieldcatalog = lt_fcat[] .LOOP AT l t_fcat INTO ls_fcat .IF ls_fcat-fieldname = 'PAYMENTSUM' .ls_fcat-no_out = space .MODIFY l t_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_ti t le = 'Flights (with Payment Sums)' .CALL METHOD gr_alvgrid->set_frontend_layoutEXPOR TINGis_layout = ls_layout .ALV_GRID介绍二(8)功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构LVC_T_SOR T创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_for_first_display这个方法的IT_SOR T参数来初始化一个排序.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_GRID介绍二(9)功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FIL T"创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法"SET_TABLE_FOR_FIRST_DISPLAY"中的参数"IT_FILTE R"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"来获取过滤条件和设置过滤条件.ALV_GRID介绍二(10)功能四:选择方式有时候,我们需要选择一些单元格,行或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.值模式可能的选择注释SPACE 等同于B 参考B 默认设置'A' 行和列的选择,无法选择单元格多行,多列用户可以使用最左边的选择按钮来选择多行'B' 单选,不可以多选行,不可以多选单元格多行,多列'C' 多选,可以多选行,不可以多选单元格多行,多列'D' 单元格的选择,可以多选单元格多行,多列,任何单元格多选用户可以使用最左边的选择按钮来选择多行注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择方式的设置的.2.设置了选择方式以后,我们可以使用很多方法来获取用户的选择.比如"GET_SELECTED_CELLS","GET_SELECTED_CELLS_ID","GET_SE LECTED_ROWS","GET_SELECTED_COLUMNS"3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PBO中,使用对应的SET方法来恢复这些选择.ALV_GRID介绍二(11)功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cxyz---Color || || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第一位,第二位代表是颜色编码(1到7),第三位是加强的设置,第四位是相反,个人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:x 颜色主要使用在1 Gray-blue headers2 Light gray List bodies3 yellow totals4 Blue-green Key columns5 green Positive threshold value6 red Negative threshold value7 orange 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 .注意:颜色设置中有优先级顺序,他们是单元格--->行--->列.ALV_GRID介绍二(12)功能六:插入超链接插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为"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 排序单元格不合并在SAP系统中,ALV(ABAP List Viewer)是一种常用的显示列表数据的方式。
它可以用来显示各种类型的数据,如内表、字典、数据库表等。
在使用ALV时,我们经常需要对数据进行排序。
然而,有时候我们希望在排序后,单元格不合并,以便于查看和分析数据。
首先,我们需要了解ALV的基本概念。
ALV是ABAP List Viewer的缩写,它是SAP系统中用于显示列表数据的一种方式。
ALV可以显示各种类型的数据,如内表、字典、数据库表等。
在使用ALV时,我们可以通过设置属性来控制显示效果,如是否显示标题、是否显示分隔线、是否显示总计等。
接下来,我们将介绍如何在使用ALV时实现单元格不合并的效果。
为了实现这个效果,我们需要设置ALV的一些属性。
具体来说,我们需要设置以下属性:1. SORTABLE:这个属性表示是否可以对数据进行排序。
默认值为X,表示可以进行排序。
2. NO_MERGE:这个属性表示是否允许单元格合并。
默认值为X,表示不允许单元格合并。
3. SORTBY:这个属性表示按照哪个字段进行排序。
默认值为空,表示不进行排序。
4. SORTORDER:这个属性表示排序的顺序。
默认值为升序,表示按照升序排序。
如果需要按照降序排序,可以将此属性设置为降序。
5. HEADER:这个属性表示是否显示标题。
默认值为X,表示显示标题。
6. DESCENDING_BORDER_AT_TOP:这个属性表示顶部边框是否为降序边框。
默认值为X,表示顶部边框为降序边框。
7. SUMMARY:这个属性表示是否显示总计。
默认值为X,表示显示总计。
8. LINE_HEIGHT:这个属性表示行高。
默认值为20,表示行高为20像素。
9. CELL_WIDTH:这个属性表示单元格宽度。
默认值为100,表示单元格宽度为100像素。
10. CELL_HEIGHT:这个属性表示单元格高度。
默认值为10,表示单元格高度为10像素。
alv tree用法
alv tree用法ALV树(ABAP List Viewer Tree)是一种在ABAP程序中使用的报表显示方式,它以树形结构展示数据,方便用户浏览和操作。
下面是ALV树的基本用法:创建ALV树报表:在ABAP程序中,使用REPORT语句创建一个新的报表。
使用ALV关键字指定报表类型为ALV树。
使用TREE关键字指定报表的显示方式为树形结构。
在SELECT-OPTIONS语句中指定用于过滤数据的选项。
在START-OF-SELECTION事件中编写代码处理数据的逻辑。
在AT-LINE-SELECTION事件中编写代码响应行的选择操作。
配置ALV树报表:使用ALV命令进入ALV树报表的配置界面。
在“列”选项卡中,配置要显示在树形结构中的列。
在“排序”选项卡中,指定按照哪个列进行排序。
在“过滤”选项卡中,设置数据的过滤条件。
在“外观”选项卡中,调整报表的外观样式。
显示ALV树报表:在ABAP程序中,使用REPORT语句调用已创建的ALV树报表。
在程序的相应事件中编写代码,处理数据和执行其他操作。
操作ALV树报表:使用鼠标点击树形结构中的节点来选择该节点。
使用上下箭头键在节点之间进行导航。
使用左右箭头键展开或折叠节点的子节点。
在节点的右键菜单中选择相应选项进行操作,如编辑、删除等。
获取ALV树报表的数据:在ABAP程序中,可以使用相应的API函数获取ALV树报表中的数据。
可以使用CL_ALV_BROWSER类的相关方法获取报表的配置信息和数据。
可以使用CL_ALV_TABLE类的相关方法获取报表的列信息和数据。
这些是ALV树的基本用法和常见操作。
你可以参考ABAP编程手册和ALV相关的文档,了解更多关于ALV树的详细信息和高级用法。
vue回显多层层数组循环遍历el-table
vue回显多层层数组循环遍历el-table
“vue回显多层层数组循环遍历el-table”这句话的意思是,在Vue.js框架中,通过循环遍历多层数组的方式,将数据展示在Element UI的el-table组件中。
这种操作主要用于在Vue.js应用中动态生成和显示数据表格。
具体来说,你需要做的是:
1.准备数据:首先,你需要有一个多层数组的数据结构。
这个数组的每个元
素本身也可能是一个数组,这样可以表示数据的层次结构。
2.创建el-table组件:在Vue的模板中,你需要创建一个el-table组件,这
是Element UI提供的用于展示数据的表格组件。
3.循环遍历数组:使用Vue的v-for指令来遍历多层数组。
对于每一层数组,
再次使用v-for遍历数组元素。
这样就可以逐层遍历整个数组结构。
4.填充数据:将遍历到的数据填充到el-table的对应单元格中。
你可以使用
el-table的属性如el-table-column来指定每一列的数据和格式。
5.显示el-table:完成数据填充后,el-table会自动显示填充后的数据。
这个操作的具体实现会依赖于你的Vue和Element UI的版本以及你的具体需求。
但是,总的来说,“vue回显多层层数组循环遍历el-table”是一种在Vue应用中展示复杂数据结构的有效方式。
el-table使用例子
el-table使用例子什么是eltable?eltable是一个基于JavaScript的库,它提供了一种简单易用的方式来创建可交互的、可排序和可过滤的HTML表格。
通过使用eltable,开发人员可以轻松地处理各种表格数据,并为用户提供更好的数据查看和操作体验。
eltable的主要特点1. 可交互性:eltable允许用户在表格中进行排序、过滤和搜索操作,以便更轻松地查找和处理数据。
2. 可排序性:eltable提供了一种方便的方式来对表格数据进行排序,用户只需点击表头即可快速按照指定的列进行升序或降序排序。
3. 可过滤性:eltable可以根据用户的需求,通过筛选条件快速控制显示哪些行,从而提供更加灵活的数据过滤功能。
4. 易用性:eltable具有简单直观的API和丰富的可定制选项,使开发人员可以轻松创建适合自己需求的表格,并且无需太多的代码。
使用eltable的步骤:步骤1:导入eltable库首先,在HTML文档中导入eltable库,可以直接从官方网站上下载eltable 的压缩包,并引入其中的js文件。
例如:<script src="path/to/eltable.min.js"></script>步骤2:创建表格容器在HTML文档中创建一个容器元素,用来承载eltable生成的表格。
例如:html<div id="table-container"></div>步骤3:配置表格参数在JavaScript代码中,通过创建一个包含配置参数的对象来定义eltable 表格的各种行为和样式。
例如:javascriptvar options = {data: [{name: 'John', age: 25}, {name: 'Mary', age: 30}], 表格数据columns: [{field: 'name', title: '姓名'}, 列定义{field: 'age', title: '年龄'}],sortable: true, 可排序filterable: true 可过滤};步骤4:创建eltable实例使用配置参数创建eltable实例,并将其附加到表格容器中。
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。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
在ALV提供的标准工具栏上我们可以实现输出结果的聚合(最大值,最小值,汇总,平均数),排序,过滤功能,同样在程序里也可以达到这些功能。
1. 声明聚合,排序,过滤所需要的变量。
DATA: lr_aggregations TYPE REF TO cl_salv_aggregations,lr_filters TYPE REF TO cl_salv_filters,lr_sorts type ref to cl_salv_sorts.2. 汇总lr_aggregations->add_aggregation(columnname = 'DISTANCE'aggregation =if_salv_c_aggregation=>total).3. 最小值lr_aggregations->add_aggregation(columnname = 'FLTIME'aggregation = if_salv_c_aggregation=>minimum).4. 过滤lr_filters->add_filter(columnname = 'CITYFROM'sign = 'I'option = 'NE'low = 'ROM'high = '').5. 排序lr_sorts->add_sort(columnname = 'CITYFROM'sequence =if_salv_c_sort=>sort_downsubtotal = 'X'obligatory = 'X').下面是效果图下面是程序的所有代码:REPORT y_xin_002.*变量定义TYPES: BEGIN OF gs_spfli,mandt TYPE spfli-mandt,carrid TYPE spfli-carrid,connid TYPE spfli-connid,countryfr TYPE spfli-countryfr,cityfrom TYPE spfli-cityfrom,airpfrom TYPE spfli-airpfrom,countryto TYPE spfli-countryto,cityto TYPE spfli-cityto,airpto TYPE spfli-airpto,fltime TYPE spfli-fltime,deptime TYPE spfli-deptime,arrtime TYPE spfli-arrtime,distance TYPE spfli-distance,distid TYPE spfli-distid,fltype TYPE spfli-fltype,period TYPE spfli-period,END OF gs_spfli.TYPES ty_spfli TYPE gs_spfli OCCURS 0.*----------------------------------------------------------------------* * CLASS lcl_alv DEFINITION*----------------------------------------------------------------------* * ALV操作类(定义)*----------------------------------------------------------------------*CLASS lcl_alv DEFINITION.PUBLIC SECTION.METHODS: getdata "取得要显示的数据RETURNING value(lt_tab) TYPEty_spfli,alv_full "全屏Grid列表处理方法IMPORTING value(lt_tab) TYPEty_spfli.PRIVATE SECTION.DATA: gr_table TYPE REF TO cl_salv_table.ENDCLASS. "lcl_alv DEFINITION*----------------------------------------------------------------------** CLASS lcl_alv IMPLEMENTATION*----------------------------------------------------------------------** ALV操作类(实现)*----------------------------------------------------------------------*CLASS lcl_alvIMPLEMENTATION.*取得要显示的数据METHOD getdata.SELECT * INTO CORRESPONDING FIELDS OF TABLElt_tab FROM spfli. ENDMETHOD. "getdata*输出全屏网格列表的方法METHOD alv_full.DATA: lr_functions TYPE REF TO cl_salv_functions_list,lr_aggregations TYPE REF TO cl_salv_aggregations,lr_filters TYPE REF TO cl_salv_filters,lr_sorts type ref to cl_salv_sorts."创建实例TRY.cl_salv_table=>factory(IMPORTINGr_salv_table = gr_tableCHANGINGt_table = lt_tab).CATCH cx_salv_msg.ENDTRY."ALV标准功能lr_functions = gr_table->get_functions().lr_functions->set_all( 'X' ).lr_aggregations =gr_table->get_aggregations( ).lr_filters = gr_table->get_filters( ).lr_sorts = gr_table->get_sorts( ).TRY."汇总lr_aggregations->add_aggregation(columnname = 'DISTANCE'aggregation =if_salv_c_aggregation=>total)."最小值lr_aggregations->add_aggregation(columnname = 'FLTIME'aggregation =if_salv_c_aggregation=>minimum)."过滤lr_filters->add_filter(columnname = 'CITYFROM'sign = 'I'option = 'NE'low = 'ROM'high = '')."排序lr_sorts->add_sort(columnname = 'CITYFROM'sequence =if_salv_c_sort=>sort_downsubtotal = 'X'obligatory = 'X').CATCH cx_salv_data_error.CATCH cx_salv_existing.CATCH cx_salv_not_found.ENDTRY."显示列表gr_table->display( ).ENDMETHOD. "alv_fullENDCLASS. "lcl_alvIMPLEMENTATION*&---------------------------------------------------------------------* *& Form f_main*&---------------------------------------------------------------------* * 整合数据,执行*----------------------------------------------------------------------* FORM f_main.DATA: lt_tab TYPE ty_spfli,lr_alv TYPE REF TO lcl_alv.CREATE OBJECT lr_alv."取得要显示的数据lt_tab = lr_alv->getdata( ).lr_alv->alv_full( lt_tab ).ENDFORM. "f_main*执行动作START-OF-SELECTION. PERFORM f_main.注:ALV TABLE部份已经全部完成。