ABAP F4使用总结!!
PARAMETERS: p_werks LIKE t001l-werks ,
p_lgort LIKE t001l-lgort .
SELECTION-SCREEN SKIP.
PARAMETERS: p_kunnr LIKE kna1-kunnr .
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_lgort.
PERFORM get_lgort CHANGING p_lgort.
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_kunnr.
PERFORM kunnr_f4help CHANGING p_kunnr.
*&---------------------------------------------------------------------*
*& Form get_event_for_user
*&---------------------------------------------------------------------*
FORM get_lgort CHANGING l_lgort LIKE p_lgort.
DATA: wa_shlp TYPE shlp_descr,
wa_selopt TYPE ddshselopt,
it_return_values TYPE STANDARD TABLE OF ddshretval,
wa_return_values TYPE ddshretval,
it_dynpfields TYPE STANDARD TABLE OF dynpread,
wa_dynpfields TYPE dynpread.
wa_dynpfields-fieldname = 'P_WERKS'.
APPEND wa_dynpfields TO it_dynpfields.
**取屏幕字段的已有值
CALL FUNCTION 'DYNP_VALUES_READ'
EXPORTING
dyname = sy-repid
dynumb = sy-dynnr
TABLES
dynpfields = it_dynpfields.
**根据表名和字段名确定使用哪个搜索帮助
CALL FUNCTION 'F4IF_DETERMINE_SEARCHHELP'
EXPORTING
tabname = 'T001L'
fieldname = 'LGORT'
IMPORTING
shlp = wa_shlp.
READ TABLE it_dynpfields WITH KEY fieldname = 'P_WERKS' INTO wa_dynpfields.
IF NOT wa_dynpfields-fieldvalue IS INITIAL.
wa_selopt-sign = 'I'.
wa_selopt-option = 'CP'.
wa_selopt-low = wa_dynpfields-fieldvalue.
wa_selopt-shlpfield = 'WERKS'.
wa_selopt-shlpname = wa_shlp-shlpname.
APPEND wa_selopt TO wa_shlp-selopt.
ENDIF.
**根据条件打开指定的搜索帮助
CALL FUNCTION 'F4IF_START_VALUE_REQUEST'
EXPORTING
shlp = wa_shlp
TABLES
return_values = it_return_values.
READ TABLE it_return_values WITH KEY fieldname = 'LGORT' INTO wa_return_values.
IF sy-subrc IS INITIAL.
l_lgort = wa_return_values-fieldval.
READ TABLE it_return_values WITH KEY fieldname = 'WERKS' INTO wa_return_values.
IF sy-subrc IS INITIAL AND wa_return_values-fieldval NE wa_dynpfields-fieldvalue.
REFRESH it_dynpfields.
wa_dynpfields-fieldvalue = wa_return_values-fieldval.
APPEND wa_dynpfields TO it_dynpfields.
**更新屏幕字段
CALL FUNCTION 'DYNP_VALUES_UPDATE'
EXPORTING
dyname = sy-repid
dynumb = sy-dynnr
TABLES
dynpfields = it_dynpfields.
ENDIF.
ENDIF.
ENDFORM. " get_event_for_user
*&---------------------------------------------------------------------*
*& Form kunnr_f4help
*&---------------------------------------------------------------------*
FORM kunnr_f4help CHANGING l_kunnr .
DATA: wa_shlp TYPE shlp_descr,
wa_shlp_desct TYPE shlp_desct ,
fcode LIKE sy-ucomm ,
wa_interface LIKE LINE OF wa_shlp-interface,
wa_fielddescr LIKE LINE OF wa_shlp-fielddescr,
wa_fieldprop LIKE LINE OF wa_shlp-fieldprop,
wa_selopt LIKE LINE OF wa_shlp-selopt,
wa_retval TYPE ddshretval,
it_retval TYPE STANDARD TABLE OF ddshretval.
DATA: subrc LIKE sy-subrc .
**根据搜索帮助取得wa_shlp
CALL FUNCTION 'F4IF_GET_SHLP_DESCR' EXPORTING
shlpname = 'VMVAA' "search help VMVAA
shlptype = 'SH'
IMPORTING
shlp = wa_shlp.
*定义 VKORG 为只读字段
LOOP AT wa_shlp-interface INTO wa_interface WHERE shlpfield = 'VKORG'.
wa_interface-value = '3020'.
wa_interface-dispfield = 'X'.
MODIFY wa_shlp-interface FROM wa_interface INDEX syst-tabix.
ENDLOOP.
LOOP AT wa_shlp-fieldprop INTO wa_fieldprop WHERE fieldname = 'VKORG'.
wa_fieldprop-shlpinput = 'X'.
wa_fieldprop-shlpseldis = 'X'.
MODIFY wa_shlp-fieldprop FROM wa_fieldprop INDEX syst-tabix.
ENDLOOP.
*定义输出字段
READ TABLE wa_shlp-interface INTO wa_interface WITH KEY shlpfield = 'VBELN'.
IF sy-subrc = 0.
wa_interface-valfield = 'X'.
* l_shlp_interface-value = tree_id.
MODIFY wa_shlp-interface FROM wa_interface INDEX sy-tabix.
ELSE.
MESSAGE e017(bmen) RAISING internal_error.
ENDIF.
* 选择界面初始值
wa_selopt-shlpname = wa_shlp-shlpname.
wa_selopt-shlpfield = 'KUNNR'.
wa_selopt-sign = 'I'.
wa_selopt-option = 'EQ'.
wa_selopt-low = '4000'.
APPEND wa_selopt TO wa_shlp-selopt.
APPEND wa_shlp TO wa_shlp_desct.
APPEND wa_shlp TO wa_shlp_desct.
CLEAR wa_shlp.
CALL FUNCTION 'F4IF_CHOOSE_SEARCHHELP'
EXPORTING
shlp_tab = wa_shlp_desct
IMPORTING
shlp = wa_shlp
fcode = fcode.
CALL FUNCTION 'F4IF_START_VALUE_REQUEST'
EXPORTING
shlp = wa_shlp
IMPORTING
rc = subrc
TABLES
return_values = it_retval.
LOOP AT it_retval INTO wa_retval.
p_kunnr = wa_retval-fieldval.
ENDLOOP.
ENDFORM. " CALL_F4HELP
ABAP F4使用总结!!的更多相关文章
- ABAP f4帮助输入多个值
*---------------------------------------------------------------------- * INITIALIZATION *---------- ...
- 【ABAP系列】SAP ABAP ALV里日期类型的F4帮助
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP ALV里日期类 ...
- 【ABAP系列】SAP F4搜索帮助的高级版
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP F4搜索帮助的高级版 ...
- [SAP ABAP开发技术总结]搜索帮助Search Help (F4)
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- ABAP ALV F4帮助
ALV F4帮助, 选值保存到ALV. TYPE-POOLS:slis. CLASS lcl_event_receiver DEFINITION DEFERRED. DATA: gt_fcat TYP ...
- ABAP 实现内表自定义的F4功能
“实现多列内容的F4功能 REPORT Z_TAB_TEST. TYPES: shlp_descr TYPE shlp_descr . DATA: BEGIN OF itab OCCURS 0 ...
- ABAP开发顾问必备:SAP ABAP开发技术总结
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- ABAP常用函数集锦
函数名 描述 SD_VBAP_READ_WITH_VBELN 根据销售订单读取表vbap中的信息EDIT_LINES 把READ_TEXT返回的LINES中的行按照TDFORMAT=“*”重新组织VI ...
- [SAP ABAP开发技术总结]消息处理Messages
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
随机推荐
- java代码随机数100个,10个一输出显示======
总结:空格???懂否?如何显示 for(int i=0;i<100;i++){ if(i%10==0){ System.out.println(); } System.out.print(n[i ...
- Java-API-Package:org.springframework.stereotype
ylbtech-Java-API-Package:org.springframework.stereotype 1.返回顶部 1. @NonNullApi @NonNullFields Package ...
- 未在本地计算机上注册 Microsoft.ACE.OLEDB.12.0 提供程序
Visual Studio 8使用了Access数据库,provider选择了ACE.OLEDB,但是运行时出现了错误,提示未在本地计算机上注册"Microsoft.ACE.OLEDB.12 ...
- sass实用知识点
本文总结sass相关核心知识点 说明:本文的内容是,我在开发实践中总结的实用性比较强的sass知识点,其他未涉及的知识,如果对你有作用请自行查阅 sass知识目录 嵌套 注释 SassScript @ ...
- 带坑的几道PHP面试题
第二题 代码如下: $i='11'; printf("%d\n",printf("%d",printf("%d",$i))); 输出结果是多 ...
- taskkill /f /t /im processName
/*@echo off */taskkill /f /t /im WINWORD.exetaskkill /f /t /im nginx.exetaskkill /f /t /im w3wp.exet ...
- python 函数对象、函数嵌套、名称空间与作用域、装饰器
一 函数对象 一 函数是第一类对象,即函数可以当作数据传递 1 可以被引用 2 可以当作参数传递 3 返回值可以是函数 3 可以当作容器类型的元素 二 利用该特性,优雅的取代多分支的if def fo ...
- Linux常用的编辑保存退出命令
Vi Vim进入编辑后退出 按ESC后 1.保存退出 :wq :x 最快捷的方法:直接按shift+zz,或者切换到大写模式按ZZ,就可以保存退出了,即是按2下大写的Z.区别::wq 强制性写入文件并 ...
- 10-30SQLserver基础--(备份和还原、分离和附加数据库)、语句查询操作
一.数据库是一个大容量的存储数据的仓库,为了保证数据完整性,防止一些数据的意外丢失等情况,需要对数据进行备份和还原. 备份数据不影响数据库的正常运行. 1.备份.还原数据库 首先对数据库进行备份,操作 ...
- 偏好设置(Preference)
一.Preference简介 (1)偏好设置是专门用来保存应用程序的配置信息的, 一般情况不要在偏好设置中保存其他数据.如果利用系统的偏好设置来存储数据, 默认就是存储在Library/Prefere ...