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.    


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP中,屏幕字段的搜索帮助可以通过使用F4帮助来创建。 首先,我们需要在屏幕字段属性中设置搜索帮助属性为“自带搜索帮助”或“值表搜索帮助”。选择“自带搜索帮助”时,系统会自动提供搜索帮助,而选择“值表搜索帮助”时,我们需要在相应的数据库表中定义搜索帮助。 接下来,我们需要在数据元素或域的定义中指定搜索帮助。在数据元素定义中,可以使用以下语句来指定搜索帮助: SEARCH HELP search_help_name 或者,在域的定义中,可以使用以下语句来指定搜索帮助: SEARCH HELP-DOM search_help_name search_help_name代表搜索帮助的名称,这个名称指向一个已经在ABAP词典中定义的搜索帮助对象。 最后,我们需要在屏幕画面上将屏幕字段与搜索帮助连接起来。在屏幕绘制逻辑中,可以使用以下代码片段来连接搜索帮助: MODULE field_name INPUT. CALL FUNCTION 'F4IF_FIELD_VALUE_REQUEST' EXPORTING fieldname = 'FIELD_NAME' tabname = 'INTERNAL_TABLE' TABLES return_tab = lt_return. LOOP AT lt_return INTO ls_return. IF ls_return-fieldname = 'FIELD_NAME'. l_value = ls_return-fieldvalue. ENDIF. ENDLOOP. ENDMODULE. 在上述代码中,'FIELD_NAME'代表屏幕字段的名称,'INTERNAL_TABLE'代表一个内部表,用于存储搜索帮助返回的结果。函数模块F4IF_FIELD_VALUE_REQUEST用于调用搜索帮助,并获取所选中的值。 使用以上步骤,我们可以在ABAP中创建屏幕字段的搜索帮助,以便用户能够在运行时选择合适的值。注意,具体的实现可能因为业务需求和系统架构的不同而有所变化,上述仅为一种常见的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值