前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ABAP之通过弹窗修改数据内容

ABAP之通过弹窗修改数据内容

作者头像
百里丶落云
发布2022-12-13 17:36:21
6650
发布2022-12-13 17:36:21
举报
文章被收录于专栏:享~方法享~方法

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第21天,点击查看活动详情

HELLO,这里是百里一个学习中的ABAPER,在工作中可能会遇到用户手工输入具体某个或者某些数据内容,当然传统的界面上直接修改也不是不可以,但是如果是在按钮或者选择屏幕中就需要这种弹出弹窗的方式进行操作.这种东西给人一种重视感,比起传统ALV的小格子数据,这种更加生动且有参与度,那么带着我们的需求,进入今天的内容.

什么弹窗

弹窗可以理解为覆盖某一个区域去执行某一个内容, 这个内容是可以警告,可以输入数据,也可以进行有效的数据警告/禁止/提醒等.跟其他语言一样,我们的弹窗内容也是类似,弹出一个框,告诉你什么事情,或者让你输入什么事情.

语法解析

我们通过调用内置函数POPUP_GET_VALUES来实现弹框数据某些对应的数据内容. 具体参数以及语法如下.

代码语言:javascript
复制
  CALL FUNCTION 'POPUP_GET_VALUES'
      EXPORTING
*       NO_VALUE_CHECK  = ' '
        popup_title     = '冲销数据'
*       START_COLUMN    = '5'
*       START_ROW       = '5'
      IMPORTING
        returncode      = lv_rtn_cd
      TABLES
        fields          = it_value
      EXCEPTIONS
        error_in_fields = 1
        OTHERS          = 2.
    IF sy-subrc = 0.
      LV_STGRD =  it_value[ 1 ]-value   .
      LV_BUDAT =  it_value[ 2 ]-value   .
      LV_MONAT =  it_value[ 3 ]-value   .

      ENDIF .

参数解释

popup_title :弹窗的标题

fields 表中存储要和用户交互的字段,

每个字段有三个参数分别是tabname:参考表;fieldname:字段名称;value:默认值。

要求字段名称必须是参考表中的数据,会自动带出搜索帮助。

START_COLUMN和START_ROW 是弹窗位置

实际案例

本次案例采取财务模块中的一个小地方,通过让用户输入冲销原因,过账日期,记账期间这三个数据内容,讲对应的输入内容存入对应的数据内容,并且展示出来. 这里讲的只是一个非常基础的demo ,在实际案例中,抬头按钮筛选,按钮过账/审核. 表体重要数据着重修改都可使用这种方式. 因为我们已经把数据的数据存入到对应的数据内表中.

数据准备

代码语言:javascript
复制
*&---------------------------------------------------------------------*
*& 
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*


  DATA LV_STGRD TYPE RF05R-STGRD .
  DATA LV_BUDAT TYPE RF05R-BUDAT .
  DATA LV_MONAT TYPE RF05R-MONAT .
  DATA: it_value  TYPE TABLE OF sval,
        wa_value  TYPE sval,
        lv_rtn_cd.

操作数据

代码语言:javascript
复制
    wa_value-tabname = 'BKPF'.
    wa_value-fieldname = 'STGRD'.
    wa_value-value = '01'.
    APPEND wa_value TO it_value.
    wa_value-tabname = 'BKPF  '.
    wa_value-fieldname = 'BUDAT'.
    wa_value-value = sy-datum   .
    APPEND wa_value TO it_value.
    wa_value-tabname = 'BKPF'.
    wa_value-fieldname = 'MONAT'.
    wa_value-value = sy-datum+4(2).
    APPEND wa_value TO it_value.

调用函数

代码语言:javascript
复制
    CALL FUNCTION 'POPUP_GET_VALUES'
      EXPORTING
*       NO_VALUE_CHECK  = ' '
        popup_title     = '冲销数据'
*       START_COLUMN    = '5'
*       START_ROW       = '5'
      IMPORTING
        returncode      = lv_rtn_cd
      TABLES
        fields          = it_value
      EXCEPTIONS
        error_in_fields = 1
        OTHERS          = 2.
    IF sy-subrc = 0.
      LV_STGRD =  it_value[ 1 ]-value   .
      LV_BUDAT =  it_value[ 2 ]-value   .
      LV_MONAT =  it_value[ 3 ]-value   .

      ENDIF .


     WRITE : LV_BUDAT .

结果展示

如图直接按F8我们直接跳出弹窗内容,让我们输入设定好的内容,这里我们既可以设定默认值也可以设定数据类型,均为参考的标准的数据元素内容.

打印一下其中一个对应的日期. 我们可以讲对应的数据存入内表,这样就可以进行更多的数据操作.这里仅仅是抛砖引玉.

百里鸡汤

旧书不厌百回读熟读深思子自知。 他年名宦恐不免今日栖迟那可追。

这里是百里,一个努力的学习者. 努力学习好好记录,点滴进步,就是成功.

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-12-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么弹窗
  • 语法解析
    • 参数解释
    • 实际案例
      • 数据准备
        • 操作数据
          • 调用函数
          • 结果展示
          • 百里鸡汤
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档