为选择屏幕的字段设置F4帮助

在没有参考 数据元素,域和搜索帮助的情况下,自定义F4 帮助

PARAMETERS: p_bukrs(4) TYPE C MATCHCODE OBJECT H_T001.
AT SELECTION-SCREEN  ON VALUE-REQUEST  FOR  p_bukrs.
        PERFORM frm_f4 CHANGING p_bukrs.
FORM frm_f4 CHANGING p_value.
   CONSTANTS cns_retfield TYPE fieldname VALUE 'BUKRS'.   
   DATA: BEGIN OF lt_value OCCURS 0, 
            bukrs LIKE t001-bukrs, "公司代码     
            butxt LIKE t001-butxt, " 公司名称      
            END OF lt_value. 
   DATA: lt_retuen LIKE TABLE OF  ddshretval WITH HEADER LINE.  
  SELECT bukrs butxt FROM t001 INTO TABLE lt_value.    
CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST' 
    EXPORTING 
        retfield        = cns_retfield  
        value_org       = 'S'   
   TABLES 
       value_tab       = lt_value     
      return_tab      = lt_retuen   
   EXCEPTIONS 
       parameter_error = 1     
   no_values_found = 2      
  OTHERS          = 3.  
  IF sy-subrc = 0. 
    READ TABLE lt_retuen  INDEX 1.    
    p_value  = lt_retuen-fieldval. 
  ELSE. 
  ENDIF. 
ENDFORM.                    "frm_f4_bukrs

 

转载于:https://www.cnblogs.com/datie/p/11495864.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值