以下是一个演示如何通过 selection-screen 中的pushbutton来动态改变屏幕上的字段的显示状态的(即显示或者隐藏)。
      注意:显示 通过本示例可知selection-screen 中的 field 的显示状态都是 的,在程序中修改其属性 active 的值为 '0' 时,该field就回隐藏起来。 但是在下一次屏幕显示前,其默认值又归为显示了。这时候可以在 at selection-screen output 事件或者 PBO中来修改active 值为 '0'即可。
另外,注意使用 modif id *** 来将selection screen 中的 field 指派到 screen-group1 中。 *** 是不超过三个字符的 id 名称,即指定了 screen-group1的值。

 *INCLUDE <icon>.
TABLES: sscrfields,
sflight. SELECTION-SCREEN: PUSHBUTTON /() pbo1 "open block 1
USER-COMMAND ucomm_o1 MODIF ID mo1,
PUSHBUTTON /() pbc1 "close block 1
USER-COMMAND ucomm_c1 MODIF ID mc1. SELECTION-SCREEN BEGIN OF BLOCK b01 WITH FRAME. SELECT-OPTIONS: s_car FOR sflight-carrid MODIF ID mc1,
* s_con FOR sflight-connid MODIF ID mc1,
* s_fld FOR sflight-fldate MODIF ID mc1,
s_pri FOR sflight-price MODIF ID mc1. SELECTION-SCREEN END OF BLOCK b01. SELECTION-SCREEN: PUSHBUTTON /() pbo2 "open block 1
USER-COMMAND ucomm_o2 MODIF ID mo2,
PUSHBUTTON /() pbc2 "close block 1
USER-COMMAND ucomm_c2 MODIF ID mc2. SELECTION-SCREEN BEGIN OF BLOCK b02 WITH FRAME. SELECT-OPTIONS: s_car2 FOR sflight-carrid MODIF ID mc2,
* s_con2 FOR sflight-connid MODIF ID mc2,
* s_fld2 FOR sflight-fldate MODIF ID mc2,
s_pri2 FOR sflight-price MODIF ID mc2. SELECTION-SCREEN END OF BLOCK b02. PARAMETERS: par_cb1() TYPE c NO-DISPLAY,
par_cb2() TYPE c NO-DISPLAY. INITIALIZATION. CONCATENATE icon_expand: '打开' '' INTO pbo1,
'打开' '' INTO pbo2. CONCATENATE icon_collapse: '关闭' '' INTO pbc1,
'关闭' '' INTO pbc2.
par_cb1 = 'X'.
par_cb2 = 'X'. AT SELECTION-SCREEN.
CASE sscrfields-ucomm.
WHEN 'UCOMM_O1'.
CLEAR par_cb1.
WHEN 'UCOMM_C1'.
par_cb1 = 'X'.
WHEN 'UCOMM_O2'.
CLEAR par_cb2.
WHEN 'UCOMM_C2'.
par_cb2 = 'X'.
ENDCASE. AT SELECTION-SCREEN OUTPUT.
LOOP AT SCREEN.
PERFORM close_block USING: par_cb1 'MO1' 'X',
par_cb1 'MC1' space,
par_cb2 'MO2' 'X',
par_cb2 'MC2' space. ENDLOOP. START-OF-SELECTION.
DO.
IF sy-index = .
EXIT.
ENDIF.
ENDDO.
*&--------------------------------------------------------------------*
*& Form close_block
*&--------------------------------------------------------------------*
* text
*---------------------------------------------------------------------*
* -->VALUE(U_CLOtextLOCK)
* -->U_MODIFY_IDtext
* -->U_CONVERT text
*---------------------------------------------------------------------*
FORM close_block USING value(u_close_block) LIKE par_cb1
u_modify_id LIKE screen-group1
u_convert. IF NOT u_convert IS INITIAL.
IF u_close_block IS INITIAL.
u_close_block = 'X'.
ELSE.
CLEAR u_close_block.
ENDIF.
ENDIF. IF ( screen-group1 = u_modify_id )
AND ( NOT u_close_block IS INITIAL ).
screen-active = ''.
MODIFY SCREEN.
ENDIF. ENDFORM. "close_block

ABAP 一个隐藏 selection-screen block的实例的更多相关文章

  1. 【ABAP系列】SAP ABAP选择屏幕(SELECTION SCREEN)事件解析

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP选择屏幕(SEL ...

  2. 选择屏幕(Selection Screen)

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  3. 一个完整的Installshield安装程序实例—艾泽拉斯之海洋女神出品(四) --高级设置二

    原文:一个完整的Installshield安装程序实例-艾泽拉斯之海洋女神出品(四) --高级设置二 上一篇:一个完整的安装程序实例—艾泽拉斯之海洋女神出品(三) --高级设置一4. 根据用户选择的组 ...

  4. 一个完整的Installshield安装程序实例-转

    一个完整的Installshield安装程序实例—艾泽拉斯之海洋女神出品(一)---基本设置一 前言 Installshield可以说是最好的做安装程序的商业软件之一,不过因为功能的太过于强大,以至于 ...

  5. tp5 r3 一个简单的SQL语句调试实例

    tp5 r3 一个简单的SQL语句调试实例先看效果核心代码 public function index() { if (IS_AJAX && session("uid&quo ...

  6. 抓到 Netty 一个隐藏很深的内存泄露 Bug | 详解 Recycler 对象池的精妙设计与实现

    欢迎关注公众号:bin的技术小屋,如果大家在看文章的时候发现图片加载不了,可以到公众号查看原文 本系列Netty源码解析文章基于 4.1.56.Final版本 最近在 Review Netty 代码的 ...

  7. Android 一个Activity保存它自己的实例

    一个Activity保存他自己的实例的作用是,在其他Activity中可以方便的调用该Activity里的方法. 我们可以使用一个静态的变量保存当前Activity的实例,并将其标志为private访 ...

  8. Delphi 中的 procedure of object (类方法存在一个隐藏参数self),简单深刻 good

    其实要了解这些东西,适当的学些反汇编,WINDOWS内存管理机制,PE结构,看下李维的VCL架构剖析可以很好理解type TMyEvent = procedure of object;这是一种数据类型 ...

  9. 关于一个隐藏和显示物品列表的demo

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

随机推荐

  1. 用实例讲解Spark Sreaming--转

    原文地址:http://www.infoq.com/cn/articles/spark-sreaming-practice 本篇文章用Spark Streaming +Hbase为列,Spark St ...

  2. Android在一个Activity中关闭另一个Activity

    比如有ActivityA, ActivityB,在ActivityB中关闭ActivityA. 解决方案: 1.在 ActivityA 里面设置一个静态的变量instance,初始化为this,在 A ...

  3. 12个免费的 Twitter Bootstrap 后台模板

    在互联网上提供很多免费的 Bootstrap 管理后台主题.所有你需要做的就是将它们下载并安装它们,这真的不是什么难事.问题是如何寻找到能够完美符合您的网站需求的主题.当然,你可以自己制作自定义的主题 ...

  4. 【深入BFC】 关于CSS中float布局,清除浮动,和margin合并的原理解析,解开你心中的那些困惑!

    BFC的通俗理解: Block Formatting Context(块级格式化上下文)是W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用. ...

  5. 研究 研究而已 java和.net的HashSet对比

    各位看官,,我不是在引发战争,,我只是想知道事情的真想,我源之于,一段代码我需要实现C#和java的两个版本功能,才发现这一个对比.讨论问题的实质,为什么会出现这样的问题.java和C#都很优秀.请大 ...

  6. React Native版本升级的正确姿势

    基于React Native(简称:RN)的APP也发布了三个版本了,RN由于两周就会发布一版从最开始项目用的0.29到最近的0.37,做为一个开源项目来说更新真是跟坐火箭般快速,当然对于我们使用的人 ...

  7. SQL--工作中遇到的

    --递归查询产品分类 WITH cte AS ( SELECT * FROM syn_Categories WHERE id = $CategoryID$ UNION ALL SELECT syn_C ...

  8. T-SQL删除重复数据

    数据重复分为两种情况:一种是每个字段都相同的完全重复,第二种是部分字段重复的结果集.比如Name字段重复,而其他字段不一定重复或者重复可以忽略. 第一种情况比较容易解决,使用select distin ...

  9. EXCEL countif函数多条件

    在MS EXCEL中,countif如果要满足多个条件怎么办呢? 1.答案就是:使用条件集合{}和sum函数. 即在countif()第二个参数中使用条件集合{},然后用sum()函数求满足这些条件的 ...

  10. python的metaclass

    元类一般用于创建类.在执行类定义时,解释器必须要知道这个类的正确的元类.解释器会先寻找类属性__metaclass__,如果此属性存在,就将这个属性赋值给此类作为它的元类.如果此属性没有定义,它会向上 ...