简单的ALV示例
在这里也推荐一条链接,很适合初学者:https://blog.csdn.net/Kang_xiong/article/details/64922576
这是一个特别基础的示例,适合没有任何ABAP基础的同学查看,很简单
示例展示:


1.SE38进入ABAP编辑器:

2. 选择本地对象后保存,此包内的程序不可传到生产系统中。如需传入生产系统,请选择可传输的包:

3. ALV创建步骤一
定义ALV的列属性表,和行属性工作区
DATA: GT_FCAT TYPE TABLE OF LVC_S_FCAT,列属性表
GS_LAYO TYPE LVC_S_LAYO. 行属性工作区
4. ALV创建步骤二:
为行属性工作区GS_LAYO 赋值。
GS_LAYO-CWIDTH_OPT = ‘X’.
5. ALV创建步骤三:
为列属性表GT_FCAT 赋值。
gs_fcat-fieldname = 'WERKS'.
gs_fcat-scrtext_l = '工厂'.
APPEND gs_fcat TO gt_fcat.
CLEAR gs_fcat.
gs_fcat-fieldname = 'MATNR'.
gs_fcat-scrtext_l = '物料编码'.
APPEND gs_fcat TO gt_fcat.
CLEAR gs_fcat.
6. ALV创建步骤四:
调用ALV显示函数
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
EXPORTING
I_CALLBACK_PROGRAM = sy-repid
IS_LAYOUT_LVC = gs_layo "行属性
IT_FIELDCAT_LVC = gt_fcat"列属性
TABLES
T_OUTTAB = gt_data
EXCEPTIONS
PROGRAM_ERROR = 1
OTHERS = 2
7. 小示例:
REPORT ZTEST1.
*======================================================================*
* Tables used in the program
*======================================================================*
TABLES: t001w,marc.
*======================================================================*
* Type declarations in the program
*======================================================================*
TYPES: BEGIN OF ty_wmatnr,
werks TYPE t001w-werks,
matnr TYPE marc-matnr,
END OF ty_wmatnr.
*======================================================================*
* Internal Tables used in the program
*======================================================================*
DATA : gt_fcat TYPE TABLE OF lvc_s_fcat, "列属性表
gs_fcat TYPE lvc_s_fcat,"列属性工作区
gs_layo TYPE lvc_s_layo. "行属性工作区
DATA: t_data TYPE TABLE OF ty_wmatnr,
s_data TYPE ty_wmatnr.
DATA: gt_data TYPE TABLE OF ty_wmatnr,
gs_data TYPE ty_wmatnr.
*======================================================================*
* Data declarations in the program
*======================================================================*
*======================================================================*
* CONSTANTS
*======================================================================*
*======================================================================*
* Input Selection Screen
*======================================================================*
SELECTION-SCREEN: BEGIN OF BLOCK a1 WITH FRAME TITLE text-001.
SELECT-OPTIONS: s_werks FOR t001w-werks ,
s_matnr FOR marc-matnr.
SELECTION-SCREEN:END OF BLOCK a1.
*======================================================================*
* Initialization
*======================================================================*
INITIALIZATION. "初始化值
*======================================================================*
* At Selection Screen
*======================================================================*
AT SELECTION-SCREEN. "选择屏幕输出后点击执行时的检查
*======================================================================*
* AT SELECTION-SCREEN OUTPUT
*======================================================================*
AT SELECTION-SCREEN OUTPUT . "可设定屏幕必输项
*======================================================================*
* AT SELECTION-SCREEN ON VALUE-REQUEST
*======================================================================*
*======================================================================*
* Start of Selection
*======================================================================*
START-OF-SELECTION.
SELECT werks matnr INTO TABLE t_data UP TO 2 ROWS FROM marc WHERE werks IN s_werks
AND matnr IN s_matnr.
IF sy-subrc NE 0.
MESSAGE s999(zcr) WITH '没有找到数据!'.
STOP.
ELSE.
PERFORM frm_get_data.
ENDIF.
*======================================================================*
* End of Selection
*======================================================================*
END-OF-SELECTION.
FORM frm_get_data.
gs_layo-cwidth_opt = 'X'.
gs_fcat-fieldname = 'WERKS'.
gs_fcat-scrtext_l = '工厂'.
APPEND gs_fcat TO gt_fcat.
CLEAR gs_fcat.
gs_fcat-fieldname = 'MATNR'.
gs_fcat-scrtext_l = '物料编码'.
APPEND gs_fcat TO gt_fcat.
CLEAR gs_fcat.
LOOP AT t_data INTO s_data.
gs_data-werks = s_data-werks.
gs_data-matnr = s_data-matnr.
APPEND gs_data TO gt_data.
CLEAR gs_data.
ENDLOOP.
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
EXPORTING
I_CALLBACK_PROGRAM = sy-repid
IS_LAYOUT_LVC = gs_layo "行属性
IT_FIELDCAT_LVC = gt_fcat"列属性
TABLES
T_OUTTAB = gt_data
EXCEPTIONS
PROGRAM_ERROR = 1
OTHERS = 2.
ENDFORM.
8. 点击转到-->文本元素可设定屏幕字段名称:


简单的ALV示例的更多相关文章
- unity Dotween插件的简单介绍及示例代码
unity里面做插值动画的插件有许多,比较常见的有itween.hotween.dotween.根据大家的反馈和实际体验来说,dotween插件在灵活性.稳定性.易用性上都十分突出.这里简单介绍下它的 ...
- [MySQL5.6] 一个简单的optimizer_trace示例
[MySQL5.6] 一个简单的optimizer_trace示例 前面已经介绍了如何使用和配置MySQL5.6中optimizer_trace(点击博客),本篇我们以一个相对简单的例子来跟踪op ...
- Skinned Mesh原理解析和一个最简单的实现示例
Skinned Mesh 原理解析和一个最简单的实现示例 作者:n5 Email: happyfirecn##yahoo.com.cn Blog: http://blog.csdn.net/n5 ...
- MongoDB下Map-Reduce使用简单翻译及示例
目录 Map-Reduce JavaScript 函数 Map-Reduce 行为 一个简单的测试 原文地址https://docs.mongodb.com/manual/core/map-reduc ...
- sqlalchemy(二)简单的连接示例
# -*- coding: utf-8 -*- import sqlalchemy from sqlalchemy import create_engine from sqlalchemy.ext.d ...
- Python正则表达式的简单应用和示例演示
前一阵子小编给大家连续分享了十篇关于Python正则表达式基础的文章,感兴趣的小伙伴可以点击链接进去查看.今天小编给大家分享的是Python正则表达式的简单应用和示例演示,将前面学习的Python正则 ...
- 一个简单的CSS示例
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8" /> 5 & ...
- 一个简单的webdynpro的ALV示例
开发alv的时候需要1.在web dynpro组件下面 的已使用的组件中添加ALV组件 SALV_WD_TABLE 2.在组件控制器的属性下面创建ALV组件SALV_WD_TABLE 3.在视图界面的 ...
- IDDD 实现领域驱动设计-一个简单的 CQRS 示例
上一篇:<IDDD 实现领域驱动设计-CQRS(命令查询职责分离)和 EDA(事件驱动架构)> 学习架构知识,需要有一些功底和经验,要不然你会和我一样吃力,CQRS.EDA.ES.Saga ...
随机推荐
- Linux机器学习软件配置
如果需要安装Python+anaconda+pycharm,就不需要单独安装Python了,因为anaconda自带Python https://www.twblogs.net/a/5b7f8c742 ...
- Cannot resolve classpath entry: /Program Files/IBM/SQLLIB/java/db2java.zip
在mybatis的逆向工程中,使用java代码和xml配置文件生成时出现以下的错误 原来自己在复制官方配置文件的参考时将这一句也复制了进来 删掉后运行即可!成功的话控制台是没有输出的
- D - Mayor's posters(线段树+离散化)
题目: The citizens of Bytetown, AB, could not stand that the candidates in the mayoral election campai ...
- 【转】解决Android 6.0 NoSuchContextException 和WEBVIEW_undefined 的问题
在 Android 4.4 操作系统上测试混合应用时,可以直接顺利的在native模式和webview模式之间切换,但是在Android6.0 操作系统上却报NoSuchContextExceptio ...
- jmeter csv 参数化
from:https://blog.csdn.net/bafasanqianzhang/article/details/77480297 [注意:csv可以上传txt,csv,另外参数必须正确否则会报 ...
- mysql修改当前用户的密码
ALTER USER USER() IDENTIFIED BY '123456';https://majing.io/posts/10000005531181
- WebAPI调用笔记
前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于Http协议的Get.Po ...
- FPM二:简单的APPLICATION-TABSTRIP(OIF)
1.新建WDA程序ZLYFPM002 2.新建视图2,窗口2,并将视图2分配到窗口2. 3.继承UIBB类IF_FPM_UI_BUILDING_BLOCK 4.创建WDA 应用程序: 5.创建WDA ...
- spring boot中实现security错误信息本地化
一.修改messages.properties 找源码中的messages.properties,复制一份放在classpath下,修改你要修改的内容 AbstractUserDetailsAuthe ...
- react - next.js 设置body style
因为next.js可以用pages文件夹中的js文件进行route,所以不需要public文件夹和html,因此没有body tag. body自带8px的maigin,我想要给整个页面设置背景颜色, ...