ALV中的fieldcat常用以及大全.doc_第1页
ALV中的fieldcat常用以及大全.doc_第2页
ALV中的fieldcat常用以及大全.doc_第3页
ALV中的fieldcat常用以及大全.doc_第4页
ALV中的fieldcat常用以及大全.doc_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

字段目录是用来控制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 字段的文本描述,输出时候显示。长描述scrtext_m 字段的文本描述,输出时候显示。中描述scrtext_s 字段的文本描述,输出时候显示。短描述lowercase 是否允许小写字母(X)decimals 输出小数点后面位数hotspot 当前列设置为热点 敏感、单机响应fix_column 固定列,不随滚动条滚动(必须在左边才生效)Key_sel 这个参数只和设置了key的字段相关,和key一起使用,可以交互式的隐藏设置为KEY的字段(alv_list有效)tech 技术字段,设置X后,该字段不会显示,也不能输出,如同MANDT字段一样的效果symbol 作为Symbol符号输出,在ALV输出内表中的字段值可以是ABAP名称,如SYM_FILLED_SQUARE(常量,不能使用引号),也可以是ID,如%,并且在报表中要使用include 语句.参考程序:RSTXSYMBno_sign 不输出正负号+、-reptext_ddic 与数据元素的主标题类似ddictxt 可选值为S,M,L,指定列标题为长描述,中描述,还是短描述,该值定义后,列标题的显示内容将固定.以上fieldcat参数对于REUSE_ALV_LIST_DISPLAY和REUSE_ALV_GRID_DISPLAY生效。以下来自/blog/851155ALV常用参数的详细描述调用功能模块:CALL FUNCTION REUSE_ALV_GRID_DISPLAYEXPORTINGi_structure_name = SPFLI /输出表的结构i_interface_check = 接口一致性检查i_callback_program = sy-repid 当前程序名is_layout = layout 输出样式it_fieldcat = fieldcat 字段定义描述表i_callback_pf_status_set = PF_STATUS_SET 触发事件调用子程序i_callback_user_command = USER_COMMAND 鼠标事件操作子程序it_events = i_events 出口程序触发事件i_callback_html_top_of_page = ALV_TOP_OF_PAGE ALV输出表头设置i_grid_settings = wl_lvc_s_glay 打印表头设置it_sort = sortable 排序设置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 降序排列Subtot 3 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. 不显示列间竖线zebra f2code = &ETA. 设置触发弹出详细信息窗口的功能码,这里是双击no_vline 这个用来设置列间隔线detail_initial_lines detail_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_PAGEform top_of_page using cl_dd type ref to cl_dd_document.语法同HTML fomat ALV_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 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)四、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 QUANTITY ALV 控制: 计量单位 9 QFIELDNAME ALV 控制: 参考计量单位的字段名称 10 IFIELDNAME ALV 控制: 内部表字段的字段名称 11 ROUND ALV 控制: ROUND 值 12 EXPONENT ALV 控制:流动表示的指数 13 KEY ALV 控制: 关键字段 关键字段,前面变蓝色14 KEY_SEL ALV 控制: 可以被隐藏的关键列 可以被隐藏的关键列15 ICON ALV 控制: 作为图标输出 此列作为图标输出16 SYMBOL ALV 控制: 输出作为符号 17 CHECKBOX ALV 控制: 作为复选框输出 复选框输出18 JUST ALV 控制: 对齐 对齐方式:R: right justifiedL: left justifiedC: centered19 LZERO ALV 控制: 输出前导零 X20 NO_SIGN ALV 控制:输出抑制符号 X,不输出符号21 NO_ZERO ALV 控制: 为输出隐藏零 X,隐藏022 NO_CONVEXT ALV 控制: 不考虑输出的转换退出 23 EDIT_MASK ALV 控制: 为输出编辑掩码 格式24 EMPHASIZE ALV 控制: 带有颜色的高亮列 列的颜色25 FIX_COLUMN ALV 控制: 固定列 26 DO_SUM ALV 控制: 总计列值 X,合计ALV_GRID介绍二(2)27 NO_SUM ALV 控制: 没有总计列值 X ,没有合计28 NO_OUT ALV 控制: 列没有输出 X ,隐藏此列29 TECH ALV 控制: 技术字段 X.也是隐藏,但是有点不一样30 OUTPUTLEN ALV 控制: 列的字符宽度 输出的长度31 CONVEXIT 转换例程 32 SELTEXT ALV 控制: 对话功能的列标识符 33 TOOLTIP ALV 控制: 列抬头的工具提示 34 ROLLNAME ALV 控制: F1 帮助的数据元素 35 DATATYPE ABAP 字典中的数据类型 ABAP 字典中的数据类型36 INTTYPE ABAP 数据类型(C,D,N,.) ABAP 数据类型(C,D,N,.)37 INTLEN 以字节计的内部长度 内容的长度38 LOWERCASE 允许/不允许小写字母 X 允许大小写39 REPTEXT 标题 40 HIER_LEVEL ALV 控制: 内部使用 41 REPREP ALV 控制: 价值是补充/补充接口的选择标准 42 DOMNAME 定义域名 43 SP_GROUP 组代码 44 HOTSPOT ALV 控制: 单击敏感 X,下面出现下划线,响应单击45 DFIELDNAME ALV 控制: 数据库中列组的字段名称 46 COL_ID ALV 控制: 列 ID 47 F4AVAILABL 字段有输入帮助吗 X.此列有搜索帮助48 AUTO_VALUE ALV 控制: 自动复制值 49 CHECKTABLE 表名 50 VALEXI 固定值存在 51 WEB_FIELD ALV 控制: 内部表字段的字段名称 52 HREF_HNDL 自然数 热点连接的句柄53 STYLE ALV 控制: 样式 下面有例子会介绍,比如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 字符字段长度 1 63 DRDN_ALIAS 字符字段长度 1 64 REF_FIELD ALV 控制: 内部表字段的参考字段名称 65 REF_TABLE ALV 控制: 内部表字段的参考表名称 66 TXT_FIELD ALV 控制: 内部表字段的字段名称 67 ROUNDFIELD ALV 控制: 带有 ROUND 说明的字段名称 68 DECIMALS_O ALV 控制: 输出小数位的编号 69 DECMLFIELD ALV 控制: 带有 DECIMALS 说明的字段名称 70 DD_OUTLEN ALV 控制: 输出字符长度 71 DECIMALS 小数点后的位数 设置小数的位数72 COLTEXT ALV 控制: 列标题 列标题73 SCRTEXT_L 长字段标签 74 SCRTEXT_M 中字段标签 75 SCRTEXT_S 短字段标签 76 COLDDICTXT ALV 控制: 确定 DDIC 文本参考 77 SELDDICTXT ALV 控制: 确定 DDIC 文本参考 78 TIPDDICTXT ALV 控制: 确定 DDIC 文本参考 79 EDIT ALV 控制: 准备输入 输出状态.X可输入80 TECH_COL ALV 控制: 内部使用 81 TECH_FORM ALV 控制: 内部使用 82 TECH_COMP ALV 控制: 内部使用 83 HIER_CPOS ALV 控制: 层次列位置 84 H_COL_KEY 树控制: 列名称/项目名称 85 H_SELECT 标识是否可以选择树控制中的列 86 DD_ROLL 数据元素 (语义域) 87 DRAGDROPID ALV 控制: 拖&放处理拖放对象 88 MAC 字符字段长度 1 89 INDX_FIELD 自然数 90 INDX_CFIEL 自然数 91 INDX_QFIEL 自然数 92 INDX_IFIEL 自然数 93 INDX_ROUND 自然数 94 INDX_DECML 自然数 95 GET_STYLE 字符字段长度 1 96 MARK 字符字段长度 1 ALV_GRID介绍二(3)2.布局控制layout布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.参照ALV的控制结构LVC_S_LAYO,以后的例子我将详细介绍如何设置行颜色和列颜色.详细的结构说明字段名 描述 Value rangeCWIDTH_OPT 最优化宽度 SPACE, XSMALLTITLE 小标题,如果设置了这个字段,则标题与列标题大小一样 SPACE, XGRID_TITLE 标题,在网格和工具条之间 最长70个字符NO_HEADERS 如果被设置,列标题隐藏 SPACE, XNO_HGRIDLN 隐藏水平线 SPACE, XNO_MERGING 禁用单元格合并 SPACE, XNO_ROWMARK (如果被设置,选择列在选择模式-这是网上摘抄话.) -禁用系统自带的行选择X为D和A的时候隐藏 SPACE, XNO_TOOLBAR 隐藏工具条 SPACE, XNO_VGRIDLN 隐藏垂直线 SPACE, XSEL_MODE 选择模式 SPACE, A, B, C, DEXCP_CONDS 合计例外 SPACE, XEXCP_FNAME 字段名称带有例外编码 最长30个字符EXCP_LED 例外作为 LED SPACE, XEXCP_ROLLN 例外文档的数据元素 SPACE, XCTAB_FNAME 带有复杂单元格颜色编码的字段名称 最长30个字符INFO_FNAME 带有简单行彩色代码的字段名称 最长30个字符ZEBRA 可选行颜色,如果设置了,出现了间隔色带 SPACE, XNO_TOTLINE 没有总计 SPACE, XNUMC_TOTAL 可以对NUMC字段进行合计 SPACE, XTOTALS_BEF 总计输出在第一行,小计在新的值之前 SPACE, XSTYLEFNAME 设置单元格,比如PUSHBUTTON 最长30个字符ALV_GRID介绍二(4)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_displayEXPORTING* I_BUFFER_ACTIVE =* I_CONSISTENCY_CHECK =* I_STRUCTURE_NAME =* IS_VARIANT =* I_SAVE =* I_DEFAULT = Xis_layout = gs_layout* IS_PRINT =* IT_SPECIAL_GROUPS =* IT_TOOLBAR_EXCLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_listit_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_BUFFER_ACTIVE 如果方法调用是静态的,可以设置这个标记,这表示,如果每次显示ALV都是相同的字段目录.既然这样,那么字段目录会被放到一个特殊的缓存里,这样加速了ALV的显示I_STRUCTURE_NAME 输出数据参考的数据字典的结构名,例如SFLIGHT.如果指定了这个参数,字段目录会自动生成,下面的参数IT_FIELDCATALOG不需要传值.IS_VARIANT 决定布局显示的变式I_SAVE 决定用户是否可以保存变式:X 只能保存全局变式U 只能保存特定变式A 都可以保存SPACE 不可以保存变式I_DEFAULT 决定用户是否可以定义默认的布局:X 可以定义默认布局,这个参数是默认的SPACE 不可以定义默认布局IS_LAYOUT 布局参数,传递布局控制的一些信息IS_PRINT 后台打印属性的参数IT_SPECIAL_GROUPS 如果在字段目录中,一些字段通过SP_GROUP被分组在一起.我们就必须为这些组传递一个组的文本内表进去IT_TOOLBAR_EXCLUDING 需要隐藏的标准的按钮的内表IT_HYPERLINK 为每个句柄分配了超连接的内表,LVC_S_HYPE中的HREF存放了超连接的地址,HANDLE指定了句柄,使用这些句柄,你可以在GRID中使用超连接IT_ALV_GRAPHICS 比较复杂,没有用过,意思好象是可以在图表中显示ALV.IT_OUTTAB 输出数据存放的内表,数据都是存放在这个内表里IT_FIELDCATALOG 字段目录IT_SORT 排序的标准IT_FILTER 过滤的标准方法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_MERGEEXPORTINGi_structure_name = SFLIGHTCHANGINGct_fieldcat = pt_fieldcatEXCEPTIONSinconsistent_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 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 .ALV_GRID介绍二(8)功能二:设置排序条件有时候我们需要使用到数据的排序.这个可以通过填充参考结构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_GRID介绍二(9)功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显示的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型LVC_T_FILT创建的内表中.过滤条件是类似一个RANGES结构的.然后把这个内表传递给方法SET_TABLE_FOR_FIRST_DISPLAY中的参数IT_FILTERFORM 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_SELECTED_ROWS,GET_SELECTED_COLUMNS3.在执行PAI以后,用户所选择的单元格,行或者列可能丢失.你可以在PBO中,使用对应的SET方法来恢复这些选择.ALV_GRID介绍二(11)功能五:颜色设置有的时候,我们需要在ALV网格上绘上一些颜色.可以给特定的行,某个特定的列,某个特定的单元格绘制颜色.如果某列被设置为关键列,这列的颜色将被自动绘制,而不需要我们额外的指定.先介绍ALV里色码.就是颜色编码,4位CHAR型.Cxyz-Color | | 1/0: 相反 开/关

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论