代码实现如下:

屏幕字段: 为一区间 对前后的两个区间字段分别开发搜索帮助;因是同一数据,可共用一个搜索帮助

第一步: 字义一内表,注:包含的若干字段为搜索帮助显示的内容;

第二步:在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.

ABAP 用户选择屏幕 搜索帮助 实现代码相关推荐

  1. 用户选择屏幕搜索帮助的代码实现

    很久不写程序了,最近接手一财务报表修改,对一用户选择屏幕开发搜索帮助:第一反应就是搜索帮助是与数据字典相关联,大凡系统表字段里的数据元素都会有默认的,但找遍了所有的表,此字段就是没有自带的搜索帮助,在 ...

  2. ABAP 动态控制选择屏幕 / Free Selection

    常规实现方式: 1. 动态控制属性,使用如下语句代码控制. 2. 标准模块实现的free selection 3. 结合逻辑数据库的动态选择屏幕 具体实现: 第一种大致通过如下代码实现 AT SELE ...

  3. SAP ABAP 动态选择屏幕

    常规实现方式: 1. 动态控制属性,使用如下语句代码控制. 2. 标准模块实现的free selection 3. 结合逻辑数据库的动态选择屏幕 具体实现: 第一种大致通过如下代码实现 AT SELE ...

  4. ABAP ALV选择屏幕下拉框实现方法

    第一步:下拉框定义 DATA:VID1   TYPE VRM_ID,      LIST1  TYPE VRM_VALUES,      VALUE1 LIKE LINE OF LIST1. DATA ...

  5. ABAP编程 选择屏幕字段权限检查--公司代码事例

    "屏幕字段 SELECTION-SCREEN BEGIN OF BLOCK A WITH FRAME . SELECT-OPTIONS G_BUKRS FOR ANLA-BUKRS. SEL ...

  6. 下拉框实现 一 - SAP ABAP 报表选择屏幕下拉框的实现

    DATA:vid TYPE vrm_id , "屏幕字段(可以是单个的I/O空间或者是Table Control中的一个单元格)           list TYPE vrm_values ...

  7. 复杂的选择屏幕搜索帮助

    REPORT ZTEST7 . TABLES :MARA . SELECT-OPTIONS :S_MATNR  FOR MARA -MATNR  NO INTERVALS . INITIALIZATI ...

  8. ABAP选择屏幕下拉框

    导语:好久没有写选择屏幕了,下面分享一个选择屏幕下拉框的实现,用户认为在选择屏幕上的搜索帮助不太友好,希望做一个下拉框来选. 一.直接引用标准值 第一种是最基础的,直接依靠表字段的搜索帮助等系统自带的 ...

  9. linux qt wifi连接,贡献自己写的,在linux,arm下的屏幕搜索wifi并连接(qt,多选择,wifi按信号排列)...

    当前位置:我的异常网» Linux/Unix » 贡献自己写的,在linux,arm下的屏幕搜索wifi并连接 贡献自己写的,在linux,arm下的屏幕搜索wifi并连接(qt,多选择,wifi按信 ...

最新文章

  1. MySQL 5.6中如何定位DDL被阻塞的问题
  2. cytoscape插件下载_cytoscape插件BinGO安装以及GO富集分析和网络可视化
  3. [***.launch] is neither a launch file in package [***] nor is [***] a launch
  4. linux 命令 kps,10个LINUX命令 超好用
  5. 实现DUBBO服务环境隔离
  6. visio 模板_盒图模板一键套用,便捷绘制精美盒图图表
  7. wkwebview html5页面,iOS使用WKWebView加载HTML5不显示屏幕宽度的问题解决
  8. sphinx 项目根目录_如何使用Sphinx工具记录Django项目
  9. linux错误日志重定向,Linux shell 重定向标准错误输出
  10. 操作系统中的处理机调度调度_操作系统中的多处理器调度
  11. greenplum 外部表 oracle,GREENPLUM使用技巧(一)- 使用外部表实现DBLINK功能
  12. Android Handler消息机制源码分析
  13. 让A超链接无效的办法 阻止元素发生默认的行为
  14. sonar-runner命令模式运行sonar
  15. js添加option设置空值_3.11 在散点图中添加标签(2)
  16. 中文近义词工具包:Synonyms
  17. ITSM系统实施成功的前提
  18. Linux基础命令01(ls , cd,clear,cat等)
  19. node-red与西门子PLC通信
  20. java中的char_java中的char是什么意思?

热门文章

  1. Python学习笔记 (1)Hello World(环境搭建+输出Hello World!)...
  2. MySQL 性能 细节 考量 (更新中......)
  3. MongoDB整库备份与还原以及单个collection备份、恢复方法
  4. Java如何判断今天本月第几周的周几?
  5. Notice: Undefined variable解决办法
  6. TurboMail邮件系统通过涉密信息系统产品认定
  7. 苹果公司有“内鬼”!ID被盗后每条只卖10元钱
  8. 《Android游戏开发详解》一2.16 区分类和对象
  9. Oracle 基础系列之1.1 oracle的安装
  10. 移动端利用-webkit-box水平垂直居中