实现了Table Control的主要的一些功能,可以作为例子参考,实现的功能有是否可编辑切换,选择某一条记录点击按钮显示详细信息,新增记录,删除记录,选择所有记录,选择光标所有记录,取消选择所有,排序,行选择栏位,列不可编辑,固定列,Table Control标题,分页功能,根据输入A字段的值显示B字段的值,某字段的值如果等于XXX就不可编辑等功能。相信这些功能已经可以满足大部份的开发了。

主程序代码:

DATA: ok_code TYPE sy-ucomm,

      save_ok TYPE sy-ucomm.

DATA: l_field TYPE char50,

      l_line  TYPE i.

TYPES: BEGIN OF ty_spfli,

         carrid TYPE spfli-carrid,

         connid TYPE spfli-connid,

         countryfr TYPE spfli-countryfr,

         cityfrom TYPE spfli-cityfrom,

         airpfrom TYPE spfli-airpfrom,

         mask(1),

END OF ty_spfli.

DATA g_lines TYPE i.

DATA sp2 TYPE TABLE OF ty_spfli WITH HEADER LINE.

DATA sp1 TYPE ty_spfli.

SELECT * INTO CORRESPONDING FIELDS OF TABLE sp2 FROM spfli.

CONTROLS content TYPE TABLEVIEW USING SCREEN 100.

content-top_line = 1.

content-lines = LINES( sp2 ).

CALL SCREEN 100.

LOOP AT sp2.

  WRITE: / sp2-carrid,sp2-connid,sp2-countryfr,sp2-cityfrom.

ENDLOOP.

*----------------------------------------------------------------------*

*  MODULE status_0100 OUTPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE status_0100 OUTPUT.

  SET PF-STATUS 'STA'.

ENDMODULE.                    "status_0100 OUTPUT

*----------------------------------------------------------------------*

*  MODULE user_command_0100 INPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE user_command_0100 INPUT.

  save_ok = ok_code.

  CLEAR ok_code.

  CASE save_ok.

    WHEN 'EXIT'.

      LEAVE TO SCREEN 0.

    WHEN 'SWITH'.

      PERFORM f_switch.

    WHEN 'SORT_UP'.

      PERFORM f_sort USING 'UP'.

    WHEN 'SORT_DOWN'.

      PERFORM f_sort USING 'DOWN'.

    WHEN 'DETAIL'.

      PERFORM f_detail.

    WHEN 'P--'.

      PERFORM f_page USING save_ok.

    WHEN 'P-'.

      PERFORM f_page USING save_ok.

    WHEN 'P+'.

      PERFORM f_page USING save_ok.

    WHEN 'P++'.

      PERFORM f_page USING save_ok.

    WHEN 'SELECT'.

      PERFORM f_select USING 'SELECT'.

    WHEN 'BLOCK'.

      PERFORM f_select USING 'BLOCK'.

    WHEN 'DESELECT'.

      PERFORM f_select USING 'DESELECT'.

    WHEN 'INSERT'.

      PERFORM f_row USING 'INSERT'.

    WHEN 'DELETE'.

      PERFORM f_row USING 'DELETE'.

  ENDCASE.

ENDMODULE.                    "user_command_0100 INPUT

*----------------------------------------------------------------------*

*  MODULE filltab OUTPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE filltab OUTPUT.

  READ TABLE sp2 INTO sp1 INDEX content-current_line.

ENDMODULE.                    "filltab OUTPUT

*----------------------------------------------------------------------*

*  MODULE readtab INPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE readtab INPUT.

  g_lines = sy-loopc.

  MODIFY sp2 FROM sp1 INDEX content-current_line.

ENDMODULE.                    "readtab INPUT

*----------------------------------------------------------------------*

*  MODULE chang_val INPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE chang_val INPUT.

  DATA lwa_cols LIKE LINE OF content-cols.

LOOP AT content-cols INTO lwa_cols.

    IF lwa_cols-screen-name = 'SP1-COUNTRYFR'

      AND sp1-countryfr = 'AA'.

      sp1-cityfrom = 'SDSDSD'.

      MODIFY sp2 FROM sp1 INDEX content-current_line.

    ENDIF.

  ENDLOOP.

ENDMODULE.                    "chang_val INPUT

*----------------------------------------------------------------------*

*  MODULE get_cursor INPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE get_cursor INPUT.

  GET CURSOR FIELD l_field LINE l_line.

ENDMODULE.                    "get_cursor INPUT

*----------------------------------------------------------------------*

*  MODULE set_cursor OUTPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE set_cursor OUTPUT.

  SET CURSOR FIELD l_field LINE l_line.

ENDMODULE.                    "set_cursor OUTPUT

*----------------------------------------------------------------------*

*  MODULE SET_EDITABLE

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE set_editable OUTPUT.

  LOOP AT SCREEN.

    IF screen-name = 'SP1-CITYFROM'.

      IF sp1-cityfrom = 'SDSDSD'.

        screen-input = 0.

        MODIFY SCREEN.

      ENDIF.

    ENDIF.

  ENDLOOP.

ENDMODULE.                    "SET_EDITABLE

*&---------------------------------------------------------------------*

*&      Form  f_page

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

*      -->CODE       text

*----------------------------------------------------------------------*

FORM f_page USING code TYPE sy-ucomm.

  DATA: i TYPE i,

        j TYPE i.

  CASE code.

    WHEN 'P--'.

      content-top_line = 1.

    WHEN 'P-'.

      content-top_line = content-top_line - g_lines.

      IF content-top_line <= 0.

        content-top_line = 1.

      ENDIF.

    WHEN 'P+'.

      i = content-top_line + g_lines.

      j = content-lines - g_lines + 1.

      IF j <= 0.

        j = 1.

      ENDIF.

      IF i <= j.

        content-top_line = i.

      ELSE.

        content-top_line = j.

      ENDIF.

    WHEN 'P++'.

      content-top_line = content-lines - g_lines + 1.

      IF content-top_line <= 0.

        content-top_line = 1.

      ENDIF.

  ENDCASE.

ENDFORM.                    "f_page

*&---------------------------------------------------------------------*

*&      Form  f_switch

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

FORM f_switch.

  DATA lwa_cols LIKE LINE OF content-cols.

LOOP AT content-cols INTO lwa_cols WHERE index > 2.

    IF lwa_cols-screen-input = 0.

      lwa_cols-screen-input = 1.

    ELSE.

      lwa_cols-screen-input = 0.

    ENDIF.

    MODIFY content-cols FROM lwa_cols INDEX sy-tabix.

  ENDLOOP.

ENDFORM.                    "f_switch

*&---------------------------------------------------------------------*

*&      Form  F_SORT

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

*      -->CODE       text

*----------------------------------------------------------------------*

FORM f_sort USING code.

  DATA: str1 TYPE string,

        str2 TYPE string,

        lwa_cols LIKE LINE OF content-cols.

READ TABLE content-cols INTO lwa_cols WITH KEY selected = 'X'.

IF sy-subrc = 0.

    SPLIT lwa_cols-screen-name AT '-' INTO str1 str2.

    IF code = 'UP'.

      SORT sp2 STABLE BY (str2) ASCENDING.

    ELSEIF code = 'DOWN'.

      SORT sp2 STABLE BY (str2) DESCENDING.

    ENDIF.

    lwa_cols-selected = ''.

    MODIFY content-cols FROM lwa_cols TRANSPORTING selected WHERE selected = 'X'.

  ENDIF.

ENDFORM.                    "F_SORT

*&---------------------------------------------------------------------*

*&      Form  f_detail

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

FORM f_detail.

  READ TABLE sp2 INTO sp1 WITH KEY mask = 'X'.

IF sy-subrc = 0 AND sp1-mask = 'X'.

    CALL FUNCTION 'POPUP_TO_DISPLAY_TEXT'

      EXPORTING

        textline1 = sp1-carrid

        textline2 = sp1-connid.

  ENDIF.

ENDFORM.                    "f_detail

*&---------------------------------------------------------------------*

*&      Form  f_select

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

*      -->CODE       text

*----------------------------------------------------------------------*

FORM f_select USING code.

  CASE code.

    WHEN 'SELECT'.

      sp1-mask = 'X'.

      MODIFY sp2 FROM sp1 TRANSPORTING mask WHERE mask IS INITIAL.

    WHEN 'BLOCK'.

      sp1-mask = 'X'.

      MODIFY sp2 FROM sp1 INDEX l_line TRANSPORTING mask.

    WHEN 'DESELECT'.

      sp1-mask = ''.

      MODIFY sp2 FROM sp1 TRANSPORTING mask WHERE mask = 'X'.

  ENDCASE.

ENDFORM.                    "f_select

*&---------------------------------------------------------------------*

*&      Form  F_ROW

*&---------------------------------------------------------------------*

*       text

*----------------------------------------------------------------------*

*      -->CODE       text

*----------------------------------------------------------------------*

FORM f_row USING code.

  DATA lwa_cols LIKE LINE OF content-cols.

  DATA: l_int TYPE i,

        lt_cols LIKE TABLE OF l_int.

  CASE code.

    WHEN 'INSERT'.

      INSERT INITIAL LINE INTO sp2 INDEX l_line.

    WHEN 'DELETE'.

      DELETE sp2 WHERE mask = 'X'.

  ENDCASE.

ENDFORM.                    "F_ROW

屏幕100的代码:

PROCESS BEFORE OUTPUT.

  MODULE status_0100.

  LOOP WITH CONTROL content.

    MODULE filltab.

    MODULE set_editable.

  ENDLOOP.

  MODULE set_cursor.

PROCESS AFTER INPUT.

  LOOP WITH CONTROL content.

    MODULE readtab.

    MODULE chang_val.

  ENDLOOP.

  MODULE get_cursor.

  MODULE user_command_0100.


ABAP 中 Table Control例子的更多相关文章

  1. ABAP table control例子

    [转自]http://blog.csdn.net/lhx20/article/details/3039909Table control用于在screen上以表格的形式显示数据,在table contr ...

  2. ABAP 表格控制(Table Control)和步循环

    表格控制(Table Control)和步循环     1.两个标准Demo: SAPMTZ60,SAPMTZ61 2.简介 3.建立Table Control程序的基本流程 4.使用步循环 5.表格 ...

  3. SAP ABAP编程 Table Control动态隐藏列

    在SAP DIALOG设计中,有时候须要动态的隐藏某些列,以下是方法. ***数据定义 CONTROLS: table_control TYPE TABLEVIEW USING SCREEN 0100 ...

  4. ABAP中的Table Control编程

          SAP中,Table Control是在Screen中用的最广泛的控件之一了,可以实现对多行数据的编辑.       简单来说,Table Control是一组屏幕元素在Screen上的重 ...

  5. ABAP Table Control

    SAP中,Table Control是在Screen中用的最广泛的控件之一了,可以实现对多行数据的编辑.  简单来说,Table Control是一组屏幕元素在Screen上的重复出现,这就是它与普通 ...

  6. 我教女朋友学编程html系列(5) html中table的用法和例子

    女朋友不是学计算机的,但是现在从事计算机行业,做技术支持,她想学习编程,因此我打算每天教她一点点,日积月累,带她学习编程,如果其他初学者感兴趣,可以跟着学. 为了将table介绍的简单.生动,具有实战 ...

  7. abap table control里面各种属性和事件的写法

    SAP中,Table Control是在Screen中用的最广泛的控件之一了,可以实现对多行数据的编辑. 简单来说,Table Control是一组屏幕元素在Screen上的重复出现,这就是它与普通屏 ...

  8. 【ABAP系列】SAP ABAP中ALV使用HTML的例子

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP中ALV使用HT ...

  9. ABAP中使用浏览器打开网页

    在SAP ABAP中可以在Screen中嵌入Html control打开网页,也可以通过调用本地的IE浏览器打开. 1.在Screen中嵌入Html control的例子,在系统中有,se38:SAP ...

随机推荐

  1. VirtualBox开发环境的搭建详解

    有关VirtualBox的介绍请参考:VirtualBox_百度百科 由于VirtualBox官网提供的搭建方法不够详细,而且本人在它指导下,从下载所需的开发包,到最后生成二进制文件,中间遇到了许多的 ...

  2. VC2008如何生成及使用DLL(图文并茂,完整版)

    博客分类: Dot net VC2008 DLL Dot net   生成.使用DLL看起来简单,但做起来才发现还是有一些地方需要注意的. 1. 打开VS2008,新建一个VC工程,选择Win32类型 ...

  3. 通过xml生成word文档

    Xml生成word总结 使用xml生成word的基本步骤在<使用xslt转化xml数据形成word文档导出.doc>中说明比较清楚了.但是其中的细节并未说到,因此自己折腾了两天总算成功了. ...

  4. Java中StringBuilder的清空方法比較

    StringBuilder 没有提供clear或empty方法. 清空有3种方法: 1)新生成一个,旧的由系统自己主动回收 2)使用delete 3)使用setLength 将三种方法循环1000万次 ...

  5. IOS引导页的编写

    我们在第一次打开App的时候,通常不是直接进入App主界面,而是会有一个能左右滑动.介绍App功能的界面.我是用NSUserDefaults + UIScrollview实现. 新建一个类,继承UIV ...

  6. mysql 初识之日志文件篇

    日志文件 1. err日志     error log 记录mysql在运行的过程中所有较为严重的警告和错误信息,以及mysql server每次启动和关闭的详细信息.系统在默认情况下关闭error ...

  7. ORA-01403: no data found

    在项目的存储过程中有这样一句话 select jgdm,jgmc into parm_mrjgdm,parm_mrjgmc From BL_KHXX  where jgdm=PARM_JGDM; 每次 ...

  8. Unicode编码(转)

    随着计算机的发展.普及,世界各国为了适应本国的语言和字符都会自己设计一套自己的编码风格,正是由于这种乱,导致存在很多种编码方式,以至于同一个二进制数字可能会被解释成不同的符号.为了解决这种不兼容的问题 ...

  9. ARMv8 Linux内核head.S源码分析

    ARMv8Linux内核head.S主要工作内容: 1. 从el2特权级退回到el1 2. 确认处理器类型 3. 计算内核镜像的起始物理地址及物理地址与虚拟地址之间的偏移 4. 验证设备树的地址是否有 ...

  10. Adrnoid开发系列(二十五):使用AlertDialog创建各种类型的对话框

    AlertDialog能够生成各种内容的对话框.可是每种对话框都会有这样的的结构: 类似下边这样的的: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTA ...