ABAP项目砖家之旅-screen和表单项目实战

2023-11-09 13:21

本文主要是介绍ABAP项目砖家之旅-screen和表单项目实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ABAP项目砖家之旅-screen和表单项目实战

  • 前言
  • 一、需求解析(abaper)
  • 二、功能实现和开发计划
    • 1.表结构
    • 2.显示界面和查询条件
      • 2.1 se38新建report程序
      • 2.2 添加搜索界面控件
      • 2.3 定义内表和其他变量方便抽取数据
      • 2.4 在开始选择事件写入sql
      • 2.5 在结束选择事件写输出列表
    • 3.编辑界面
      • 3.1在显示界面添加0100屏幕
      • 3.2 修改0100屏幕
      • 3.3 添加新增按钮
  • 总结


前言

直接上一个screen表单的需求来实战下,需求顾问提供fs-功能说明书,一般会描述下想要什么界面,录入什么数据,录入后如何使用等。我们按照需求整理成我们编程人员能否理解的即可
上需求:sap用户比较贵,我们有大堆的销售人员需要录入简单的资料,于是业务提了需要新建一个销售人员管理界面,需要用户、姓名、密码、截止日期、可选区域、根据区域可选门店。

一、需求解析(abaper)

直接看字段:用户、姓名、密码、截止日期、区域、门店。直接得出是需要建立透明表了,再看用户要输入信息肯定需要一个屏幕输入;虽然没有提要不要列表,但还是要考虑他们怎么查看和管理建立的销售人员;那就做个简单的显示界面吧(alv更好,后面alv实战再做);显示界面还不行,人家用上了肯定还要搜索的,提一送三没办法。都来吧做全套,一条龙吧。
注意:abap对象新建和程序命名都有一套规则,上一篇有截图,欢迎大家查看下

二、功能实现和开发计划

分为表结构、管理界面(显示界面)、编辑界面,开发计划是几分钟做好表结构,然后做显示界面,最后做编辑界面

1.表结构

直接SE11,新建表,错!必须先统计下字段、数据元素、长度等,业务不提供的话,我们abaper自己搞个表吧

字段描述元素类型长度小数备注
zname用户zenamezmnamechar100
zdesc姓名zedesczmdescchar200
zdate截止日期zedatezmdatedats80yyyymmdd格式
zpsw密码zepswzmpswchar100暂不加密
zarea区域zeareazmareachar20
zwerks门店zenamezmchar40

元素较简单重复使用概率不大,故暂不使用数据元素和域,注意主键,不然容易覆盖
在这里插入图片描述

插入数据:
在这里插入图片描述

2.显示界面和查询条件

2.1 se38新建report程序

代码如下(示例):
在这里插入图片描述

2.2 添加搜索界面控件

可以使用parameters(单值)或者select-option(区间)

select-OPTIONS:s_zname for zttest_01-zname,s_zdesc for zttest_01-zdesc .

保存,然后点击:转到——文本元素,点击选择文本(上面定义控件的文本),勾选“数据字典参考”,自动带出文本,也可不勾选自己写
在这里插入图片描述

2.3 定义内表和其他变量方便抽取数据

DATA:LT_ZTTEST TYPE TABLE OF zttest_01 , "跟透明表一致的内表WA_ZTTEST LIKE LINE OF LT_ZTTEST . "工作区(行)
FIELD-SYMBOLS:<FS> LIKE LINE OF LT_ZTTEST. "指针(行)

2.4 在开始选择事件写入sql

START-OF-SELECTION .select * from zttest_01 into TABLE LT_ZTTESTwhere zname in s_znameand zdesc in s_zdesc .

2.5 在结束选择事件写输出列表

END-OF-SELECTION ."不一定在这个事件,也可以跟2.4一起WRITE:'搜索条件——用户:',s_zname,';姓名:',s_zdesc .ULINE.WRITE:TEXT-000,TEXT-001,TEXT-002,TEXT-003,TEXT-004,TEXT-005.ULINE.IF LT_ZTTEST[] is not INITIAL.LOOP AT LT_ZTTEST ASSIGNING <fs>.IF <fs>-ZDATE ge sy-datum.WRITE icon_green_light AS ICON .ELSE.WRITE icon_red_light AS ICON .ENDIF.WRITE: <FS>-ZNAME,<FS>-zdesc ,<FS>-ZDATE,<FS>-ZAREA,<FS>-ZWERKS . ULINE.ENDLOOP.ENDIF.

界面显示:
在这里插入图片描述

3.编辑界面

3.1在显示界面添加0100屏幕

在这里插入图片描述

3.2 修改0100屏幕

双击点开0100屏幕,点击“字典”按键,然后输入需要维护的表名字,点击“从字典获取”按键,然后选定需要维护的行,点击确定(绿勾)
在这里插入图片描述
然后鼠标遇到屏幕适当位置,点击一下即可定位所有字段控件
在这里插入图片描述
美化下,添加描述(sap标准数据元素-域组成的字段会自动带出,用char等定义的字段需要自己添加文本控件)
在这里插入图片描述
保存,然后修改屏幕的代码:

PROCESS BEFORE OUTPUT.MODULE STATUS_0100."写状态栏(工具栏)和加载数据的代码
*
PROCESS AFTER INPUT.MODULE USER_COMMAND_0100. "写按键保存、返回

再双击MODULE STATUS_0100的“”STATUS_0100“”,提示不存在是否新建,则新建include程序命名为“ZTEST_DYNPRO_MOD”,添加获取双击行和GUI状态(工具栏)按键的代码:

MODULE STATUS_0100 OUTPUT. "pbo 事件SET PF-STATUS 'ZTEST_DYNPROSTA0100'."双击,新建一个0100屏幕的GUI状态,才能使用保存按键SET TITLEBAR '二级用户编辑界面'.IF SY-LISEL IS NOT INITIAL.READ TABLE LT_ZTTEST INTO WA_ZTTEST INDEX SY-TABIX .IF sy-subrc = 0.ZTTEST_01 = WA_ZTTEST .ENDIF.ENDIF.
ENDMODULE.
*&---------------------------------------------------------------------*
*&      Module  USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE USER_COMMAND_0100 INPUT. "pai事件CASE SY-UCOMM.WHEN 'BACK' OR '&BACK'.LEAVE TO SCREEN 0 .WHEN '%EX' OR '&UP' .leave PROGRAM .WHEN 'RW' OR '&EXIT'.leave PROGRAM .WHEN 'SAVE' OR '&SAVE'.MODIFY zttest_01 FROM zttest_01 .IF sy-subrc = 0.MESSAGE '保存成功' type 'S'.ELSE.MESSAGE '保存失败' type 'E'.ENDIF.WHEN OTHERS.ENDCASE.
ENDMODULE.

当然添加个GUI状态这样保存按键才能使用:
在这里插入图片描述
最后测试一下:保存已经提示成功,但是数据貌似没刷新。封装sql获取数据和write的方法,重新执行下即可,代码如下:

MODULE USER_COMMAND_0100 INPUT.CASE SY-UCOMM.WHEN 'BACK' OR '&BACK'.LEAVE TO SCREEN 0 .WHEN '%EX' OR '&UP' .leave PROGRAM .WHEN 'RW' OR '&EXIT'.leave PROGRAM .WHEN 'SAVE' OR '&SAVE'.MODIFY zttest_01 FROM zttest_01 .IF sy-subrc = 0.MESSAGE '保存成功' type 'S'.PERFORM GET_DATA."更新数据ELSE.MESSAGE '保存失败' type 'E'.ENDIF.WHEN OTHERS.ENDCASE.
ENDMODULE.
*&---------------------------------------------------------------------*
*& Report ZTEST_DYNPRO
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT ZTEST_DYNPRO   .
TABLES:zttest_01 .DATA:LT_ZTTEST TYPE TABLE OF zttest_01 ,WA_ZTTEST LIKE LINE OF LT_ZTTEST .
FIELD-SYMBOLS:<FS> LIKE LINE OF LT_ZTTEST.select-OPTIONS:s_zname for zttest_01-zname,s_zdesc for zttest_01-zdesc .INITIALIZATION.AT SELECTION-SCREEN .AT LINE-SELECTION.CALL SCREEN '0100' .
START-OF-SELECTION .PERFORM GET_DATA.END-OF-SELECTION .PERFORM WRRTEOUT.TOP-OF-PAGE.
END-OF-PAGE .INCLUDE ztest_dynpro_mod.
*&---------------------------------------------------------------------*
*&      Form  WRRTEOUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM WRRTEOUT .WRITE:'搜索条件——用户:',s_zname,';姓名:',s_zdesc .ULINE.WRITE:TEXT-000,TEXT-001,TEXT-002,TEXT-003,TEXT-004,TEXT-005.ULINE.IF LT_ZTTEST[] is not INITIAL.LOOP AT LT_ZTTEST ASSIGNING <fs>.IF <fs>-ZDATE ge sy-datum.WRITE icon_green_light AS ICON .ELSE.WRITE icon_red_light AS ICON .ENDIF.WRITE: <FS>-ZNAME,<FS>-zdesc ,<FS>-ZDATE,<FS>-ZAREA,<FS>-ZWERKS . ULINE.ENDLOOP.ENDIF.
ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  GET_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM GET_DATA .REFRESH  LT_ZTTEST.select * from zttest_01 into TABLE LT_ZTTESTwhere zname in s_znameand zdesc in s_zdesc .
ENDFORM.

3.3 添加新增按钮

回到主程序ZTEST_DYNPRO。
引入icon和添加按键

TYPE-POOLS icon."使用icon库
TABLES:zttest_01 ,sscrfields. "选择屏幕上的字段结构
DATA:bttxt TYPE smp_dyntxt . "菜单、按键
SELECTION-SCREEN: FUNCTION KEY 1 . "添加f8同行按键
INITIALIZATION."按键初始化BTTXT-ICON_ID = ICON_ADD_ROW .bttxt-ICON_TEXT = '新增'.sscrfields-FUNCTXT_01 = bttxt .
AT SELECTION-SCREEN .CASE sscrfields-ucomm.WHEN 'FC01'.CALL SCREEN 0100. "新增界面WHEN OTHERS.ENDCASE.

当然也要在0100屏幕添加按钮
在这里插入图片描述

MODULE USER_COMMAND_0100 INPUT.CASE SY-UCOMM.WHEN 'BACK' OR '&BACK'.LEAVE TO SCREEN 0 .WHEN '%EX' OR '&UP' .leave PROGRAM .WHEN 'RW' OR '&EXIT'.leave PROGRAM .WHEN 'SAVE' OR '&SAVE'.MODIFY zttest_01 FROM zttest_01 .IF sy-subrc = 0.MESSAGE '保存成功' type 'S'.PERFORM GET_DATA."更新数据ELSE.MESSAGE '保存失败' type 'E'.ENDIF.WHEN '&ADDNEW'. "新增按键REFRESH LT_ZTTEST.CLEAR zttest_01.CALL SCREEN 0100.WHEN OTHERS.ENDCASE.
ENDMODULE.

总结

今天内容到此为止,相信通过这个简单实战,大家可以在项目写简单的录入界面了。当然还有打印、复制、删除、切换修改编辑等功能,这里不一一列举了

这篇关于ABAP项目砖家之旅-screen和表单项目实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/376362

相关文章

解决Maven项目报错:failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题

《解决Maven项目报错:failedtoexecutegoalorg.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题》这篇文章主要介... 目录Maven项目报错:failed to execute goal org.apache.maven.pl

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt