POH和POV事件获得屏幕字段的值

一、概念

PROCESS ON HELP-REQUEST.
"当用户查看帮助信息时(或按下F1键)被触发、事件结束后将处理当前
	FIELD FIELD_NAME MODULE HELP_MODULE.	屏幕
PROCESS ON VALUE-REQUEST.
"当用户按下查询帮助按键时(或按下F4键)被触发,事件结束后将继续处
	FIELD FIELD_NAME MODULE F4_MODULE.	理当前屏幕

在SCREEN显示之前,系统会自动将程序变量值存放到屏幕字段中:在PAI事件中,系统会自动将屏幕字段的值更新到相应的程序变量中。
在SCREEN LOGIC中我们还有POH和POV事件,所以需要调用DYNP_VALUES_READ函数来读取屏幕字段值。

二、业务场景

屏幕上有FIELD_1和FIELD_2两个字段,必须根据FIELD_1的值后台查询对应搜索帮助的数据。由于PAI尚未被执行,屏幕字段FIELD_1的值尚未更新到程序变量FIELD_1。
此时我们可以调用DYNP_VALUES_READ 来实现,读取FIELD_1字段值

三、实现

  DATA:DYNPFIELDS  TYPE TABLE OF DYNPREAD WITH HEADER LINE.
  DYNPFIELDS-FIELDNAME = 'FIELD_1'.
  APPEND  DYNPFIELDS.
  CALL FUNCTION 'DYNP_VALUES_READ'
    EXPORTING
      DYNAME     = SY-REPID
      DYNUMB     = SY-DYNNR
    TABLES
      DYNPFIELDS = DYNPFIELDS.
  IF SY-SUBRC =  0.
    READ TABLE DYNPFIELDS WITH   KEY  FIELDNAME   = 'FIELD_1'.
    IF SY-SUBRC = 0.
      ZMMT001-WERKS =   DYNPFIELDS-FIELDVALUE.
    ENDIF.
  ENDIF.
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值