ABAP 用户选择屏幕 搜索帮助 实现代码

代码实现如下:

屏幕字段: 为一区间 对前后的两个区间字段分别开发搜索帮助;因是同一数据,可共用一个搜索帮助

第一步: 字义一内表,注:包含的若干字段为搜索帮助显示的内容;

第二步:在INITIALLIXATION 事件 初始化此内表的值,就是用户想看到的预选清单;

第三步:在选择屏幕事件中对屏幕参数作如下处理:

  AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_xxx-low.
       PERFORM FRM_GET_KOSTL.

  AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_xxx-HIGH.
    PERFORM FRM_GET_KOSTL.

  因参数P_xxx在屏幕上为一选择区间

 

代码:

  * F4 变量定义.
data: LT_SKAT  like table of SKAT with header line.
data : begin of LT_VALUE  occurs 0,
         VALUE(50) type C,
       end of LT_VALUE.
       data : LT_FIELD_TAB type table of DFIES,
      WA_FIELD like line of LT_FIELD_TAB,
      LT_RETURN_TAB type table of DDSHRETVAL,
      WA_RETURN like line of LT_RETURN_TAB.

* F4 执行

  start-of-selection.

  at selection-screen on value-request for  S_SAKNR-LOW.
perform show_values.

at selection-screen on value-request for S_SAKNR-HIGH.
perform show_values.

 

*F4 子程序

  FORM SHOW_VALUES .

  refresh LT_VALUE.
  refresh LT_FIELD_TAB.
  refresh LT_RETURN_TAB.

  select
    SAKNR
    TXT50
     from SKAT
     into corresponding fields of table LT_SKAT
     where SPRAS = 'EN'.

  clear WA_FIELD.
  WA_FIELD-TABNAME = 'SKAT'.
  WA_FIELD-FIELDNAME = 'SAKNR'.
  append WA_FIELD to LT_FIELD_TAB.

  clear WA_FIELD.
  WA_FIELD-TABNAME = 'SKAT'.
  WA_FIELD-FIELDNAME = 'TXT50'.
  append WA_FIELD to LT_FIELD_TAB.


  clear LT_VALUE.
  loop at LT_SKAT.
    LT_VALUE-VALUE = LT_SKAT-SAKNR.
    append  LT_VALUE.
    LT_VALUE-VALUE = LT_SKAT-TXT50.
    append  LT_VALUE.
  endloop.


  call function 'F4IF_INT_TABLE_VALUE_REQUEST'
    exporting
      RETFIELD        = 'SAKNR'
    tables
      VALUE_TAB       = LT_VALUE
      FIELD_TAB       = LT_FIELD_TAB
      RETURN_TAB      = LT_RETURN_TAB
    exceptions
      PARAMETER_ERROR = 1
      NO_VALUES_FOUND = 2
      others          = 3.
  if SY-SUBRC <> 0.
    message id SY-MSGID type SY-MSGTY number SY-MSGNO
            with SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
  else.
    read table LT_RETURN_TAB into WA_RETURN index 1.
    S_SAKNR = WA_RETURN-FIELDVAL.
  endif.

ENDFORM.    


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值