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代码输出1到100的质数
总结:循环,循环.. package com.dfd; import java.util.Scanner; //输出0到100的质数 //要判断当到100时候,等于2的直接输出,能被2整除的不输出, ...
- 用nfs挂载内核时出错 ERROR: Cannot umount的解决办法
SMDK2440 # nfs 30000000 192.168.1.106:/work/nfs_root/uImage ERROR: resetting ...
- 使用Asset Pipeline管理rails生产环境静态资源实现步骤
1. 修改项目中指向静态资源文件的链接 a) 访问静态资源文件 <%= stylesheet_link_tag "application", media: &q ...
- Mybatis 内置 Java 类型别名与 typeHandlers
aliases There are many built-in type aliases for common Java types. They are all case insensitive, n ...
- myeclipse与eclipse的web项目部署区别
一.myeclipse之web项目的部署(发布)流程 web项目的部署(发布)流程2008-01-18 14:35 在myeclipse下新建web工程abc.系统设置默认如下: 项目保存位置:wor ...
- SqlServer——事务一进阶之锁的概念(SqlServer技术内幕 T-SQL程序设计 第九章)
一.事务的概念及ACID特性 对于单独一条SQL语句,数据库会隐式的将其作为事务,即该SQL语句要么执行成功,要么失败(相当于不执行),而我们通常说的事务就是将多条SQL语句放在 begin ...
- 问题:oracle 字符串转换成日期;结果:[oracle] to_date() 与 to_char() 日期和字符串转换
to_date("要转换的字符串","转换的格式") 两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,& ...
- Template Method模式和Strategy模式有何异同
Template Method模式和Strategy模式有何异同 博客分类: 设计模式 Java Template Method模式很容易理解,就是由基类提供一个模板,将各子类中不变的行为提取到基类 ...
- valgrind详解
调不尽的内存泄漏,用不完的Valgrind Valgrind 安装 1.valgrind 安装包下载地址:http://valgrind.org/downloads/repository.html(使 ...
- C++实现数组的排序/插入重新排序/以及逆置操作
插入新的数字重新排序 分析:将新的数字与已经排序好的数组中的数字一一比较,直到找到插入点,然后将插入点以后的数字都向后移动一个单位(a[i+1]=a[i]),然后将数据插入即可. 代码: #inclu ...