zoukankan      html  css  js  c++  java
  • cl_demo_output=>display 介绍

    Methods of CL_DEMO_OUTPUT

    PS:自己测试是display后的内表不能带表头。

    类CL_DEMO_OUTPUT 在示例程序中创造了很多简单的数据输出的方法而不需要经典的list。这个类可以通过静态或实例化的方式使用。下面这些方法在输出流中创建输出。

    • 方法BEGIN_SECTION,NEXT_SECTION和END_SECTION创建标题和开始或结束标题级别。
    • 方法WRITE_DATA,WRITE_TEXT,WRITE_XML,WRITE_JSON和WRITE_HTML显示不同类型的输出。
    • 使用WRITE_DATA可以输出基本类型对象(不是引用类型),结构的组件和内表的行类型。
    • 其它方法创建格式化的输出数据如xml ,json,HTML。
    • 方法写是通用的。它处理ABAP数据和文本(非比例格式)。
    • 方法DISPLAY_……(只提供静态方法)工作方式为WRITE_…,但请关闭当前输出流并打开一个新的输出流。如果SAP GUI可用,则输出将显示在窗口中。
    • 方法行创建一个横向行。
    • 方法DISPLAY关闭当前输出流并打开一个新的输出流。如果SAP GUI可用,则输出将显示在窗口中。还可以选择像forWRITE一样传递数据来显示。
    • 方法GET的工作方式与DISPLAY类似,但不显示数据。相反,格式化的输出数据以文本字符串的形式返回,可以进一步处理。
    • 标准输出格式是HTML。您还可以选择使用制表器和换行符来选择简单的文本格式。您可以为静态方法选择带有SET_MODE方法的格式,也可以为实例方法选择factory methodNEW的输入参数模式。
    • CL_DEMO_OUTPUT类在自SP07以来的7.03/7.31版本和更高版本中可用。它有一个类文档。

    代码示例

    最简单和常见的用法如下:

    SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
    CL_DEMO_OUTPUT=>DISPLAY( IT_TAB ).

     使用CL_DEMO_OUTPUT的多个静态方法的程序可能如下所示:

    SELECT * FROM SCARR INTO TABLE @DATA(CARRIERS).
    CALL TRANSFORMATION ID SOURCE CARRIERS = CARRIERS
                           RESULT XML DATA(XML).
    CL_DEMO_OUTPUT=>BEGIN_SECTION( `Some Text` ).
    CL_DEMO_OUTPUT=>WRITE_TEXT( |blah blah blah 
    | && |blah blah blah| ).
    CL_DEMO_OUTPUT=>NEXT_SECTION( `Some Data` ).
    CL_DEMO_OUTPUT=>BEGIN_SECTION( `Elementary Object` ).
    CL_DEMO_OUTPUT=>WRITE_DATA( CARRIERS[ 1 ]-CARRID ).
    CL_DEMO_OUTPUT=>NEXT_SECTION( `Internal Table` ).
    CL_DEMO_OUTPUT=>WRITE_DATA( CARRIERS ).
    CL_DEMO_OUTPUT=>END_SECTION( ).
    CL_DEMO_OUTPUT=>NEXT_SECTION( `XML` ).
    CL_DEMO_OUTPUT=>WRITE_XML( XML ).
    CL_DEMO_OUTPUT=>DISPLAY( ).

     由于这看起来很丑陋,如果你在一个程序中调用了类的3到4个以上的方法,最好使用实例方法而不是静态方法:

    CL_DEMO_OUTPUT=>NEW(
      )->BEGIN_SECTION( `Some Text`
      )->WRITE_TEXT( |blah blah blah 
    | && |blah blah blah|
      )->NEXT_SECTION( `Some Data`
      )->BEGIN_SECTION( `Elementary Object`
      )->WRITE_DATA( CARRIERS[ 1 ]-CARRID
      )->NEXT_SECTION( `Internal Table`
      )->WRITE_DATA( CARRIERS
      )->END_SECTION(
      )->NEXT_SECTION( `XML`
      )->WRITE_XML( XML
      )->DISPLAY( ).

     静态方法和实例方法如何具有相同的名称?

    实例方法是接口方法。方法NEW返回一个类型为IF_DEMO_OUTPUT的引用变量。这个接口由CL_DEMO_OUTPUT实现。接口方法具有与类的静态方法相同的名称。 

    为什么要将这些方法链接起来呢?

    为了方便起见,每个实例方法都返回自我参考。

    如果你想要一个更简单的输出,你可以切换到文字模式:

    SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
    CL_DEMO_OUTPUT=>new( 'TEXT' )->DISPLAY( it_tab ).

     如果你想自己处理生成的格式化数据,你可以使用GET而不是DISPLAY:

    SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
    DATA(HTML) = cl_demo_output=>GET( it_tab ).
    CL_ABAP_BROWSER=>SHOW_HTML( HTML_STRING = HTML ).

    这将产生与上面第一个示例相同的输出。

     您还可以检查和运行以下程序,以获得所有可能性的完整概述:

    • DEMO_USAGE_OUTPUT_STATIC
    • DEMO_USAGE_OUTPUT_INSTANCE

    例子如下:

    ADT中的ABAP关键字文档(即Eclipse中的ABAP)提供了一个框架如何使用CL_DEMO_OUTPUT的示例。如果ABAP示例库的示例使用CL_DEMO_OUTPUT,则文档框架允许您执行示例并显示输出。这是通过从cl_demo_output获取HTML输出并将其合并到(非SAP GUI)文档显示中来实现的。

    另一个例子相当引人注目。CL_DEMO_OUTPUT在SAP Teched 2013上亮相!

    以下是Vishal Sikka博士主题演讲的截图:

    (B.t.w。,请参阅AMDP, SQLScript与Open SQL的比较,以进一步查看该示例的性能结果;上面糟糕的ABAP结果来自嵌套的SELECT循环…)。

  • 相关阅读:
    网页爬虫小记:两种方式的爬取网站内容
    AOP中使用Aspectj对接口访问权限进行访问控制
    Spring Boot应用总结更新
    SpringBoot集成mybatis配置
    经验收集
    关于阿拉伯文开发的一点经验
    关于IDataReader.GetSchemaTable的一些事情
    removing vmware debugger from visual studio
    SQL Server 2008 R2 附加数据库 “尝试打开或创建物理文件 拒绝访问”的解决办法
    Visual Studio 2013 ReportViewer Control
  • 原文地址:https://www.cnblogs.com/BruceKing/p/11445610.html
Copyright © 2011-2022 走看看