本文主要是介绍SAP中如何建立F4搜索帮助,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在写ABAP代码的时候,我们经常会遇到这样的问题,当你自己在数据字典中建立了一个配置表时,你在屏幕上引用了表中的某个字段.同时你想要在屏幕上提供选择,让用户可以直接选择而不用输入内容.这时我们就会用到-F4搜索帮助.接下来我将给大家介绍两种建立搜索帮助的方法.
方法一:在ABAP数据字段中直接建立相关字段的搜索帮助.
具体步骤:
1.事务码SE11打开数据字典,选中搜索帮助,填写名称,点击创建.
2.填写基本相关信息,搜索帮助描述,取数的表,显示的对话框类型.
3.填写搜索帮助参数,字段名称,输入输出属性,显示位置次序,数据元素.
4.保存,激活.
5.打开要建立搜索帮助的表,选中要建立搜索帮助的字段,点击SRCH HELP,填入你建立好的搜索帮助的名称.
6.保存,激活表.
7.重新保存要用到表中搜索帮助的程序,激活后就可以使用搜索帮助来选择值了.
注:此方法比较直观,但是有相关的前提:要添加搜索帮助的表中的字段,必须要有参照的数据元素. 没有数据元素无法建立搜索帮助.所以前提就是我们要事先维护好数据元素.
方法二:在ABAP程序中直接写相关代码来实现.
具体步骤:
1.添加VALUE-REQUEST事件.
示例代码:
AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_XILEI-LOW.
PERFORM FRM_XILEI_SELECT.
2.在子程序中实现搜索帮助功能.
示例代码:
FORM FRM_XILEI_SELECT .
*细类的搜索帮助
DATA: RT_TAB LIKE DDSHRETVAL OCCURS 0 WITH HEADER LINE.
DATA: BEGIN OF IT_XILEI OCCURS 0,
XILEI LIKE ZSFQ10-XILEI,
END OF IT_XILEI.
SELECT XILEI INTO CORRESPONDING FIELDS OF TABLE IT_XILEI FROM ZSFQ10.
CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
EXPORTING
RETFIELD = 'XILEI'
DYNPPROG = SY-REPID
DYNPNR = SY-DYNNR
DYNPROFIELD = 'S_XILEI-LOW'
VALUE_ORG = 'S'
CALLBACK_PROGRAM = SY-REPID
TABLES
VALUE_TAB = IT_XILEI
RETURN_TAB = RT_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.
ENDIF.
ENDFORM. " FRM_XILEI_SELECT
3.保存,激活程序后,即可在屏幕上使用搜帮助了.
注:此方法不是太直观,但是不用在数据字典中建立相关的数据,只需在程序中动态提取显示.
总结:两种实现方法,均可以实现搜索帮助的功能,各有特点,可以视具体情况使用.
这篇关于SAP中如何建立F4搜索帮助的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!