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 \n| && |blah blah blah| ).
CL_DEMO_OUTPUT=>NEXT_SECTION( `Some Data` ).
CL_DEMO_OUTPUT=>BEGIN_SECTION( `Elementary Object` ).
CL_DEMO_OUTPUT=>WRITE_DATA( CARRIERS[ ]-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 \n| && |blah blah blah|
)->NEXT_SECTION( `Some Data`
)->BEGIN_SECTION( `Elementary Object`
)->WRITE_DATA( CARRIERS[ ]-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循环…)。

cl_demo_output=>display 介绍的更多相关文章

  1. display属性详解

    内容: 1.display介绍 2.display分类 3.块级标签和内联标签 4.inline-block应用 1.display介绍 display:display属性设置元素如何被显示 2.di ...

  2. ABAP中的AMDP(ABAP-Managed Database Procedures )

    ABAP管理下的数据库存储过程(ABAP-Managed Database Procedure,以下简称AMDP)是在APAP on SAP HANA开发中的一种优化模式.AMDP使用数据库语言书写, ...

  3. 我的BRF+自学教程(一):公式(formula)

    Business Rule Framework Plus(业务规则框架,以下简称BRFplus或BRF+)是一个强大的工具, 它允许用户以直观的方式对规则建模,并在不同的应用程序中重用这些规则.通过它 ...

  4. 【第四篇】SAP ABAP7.5x新语法之CREATE DATA&INTERFACE

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文地址:SAP ABAP7.5x系列之CREATE DA ...

  5. ABAP实现Geohash

    前几天群里有人问ABAP有没有Geohash函数,用来帮助SAP存储门店位置.实现对附近门店查找的功能.因为没有查到,所以我动手写了一个. Geohash是什么 Geohash是一种公共域地理编码系统 ...

  6. ABAP实现Blowfish加密算法

    看到SAP社区中有人问是否存在ABAP实现的Blowfish加密算法,无人回答.于是动手实现了一个blowfish-abap.通过blowfish-abap可以在SAP系统中使用Blowfish对数据 ...

  7. 动态SQL屏幕条件选择(里面还有赋值的新语法)

    有时候屏幕条件中使用PARAMETERS时候,如果你为空的话,会查不出数据,但是可能你的想法是不想限制而已,但是系统默认理解为了空值,这个时候,如果取判断一下条件是不是空,在SQL里决定写不写的话,会 ...

  8. ABAP 7.4 新语法-内嵌生命和内表操作

    1.内嵌声明 2.内表操作 3.opensql ************************************************************************ 1. ...

  9. ABAP 7.52 中的Open SQL新特性

    S/4 HANA 1709 已经在几个月前发布,随之而来的是ABAP 7.52. 本文翻译了更新文档中有关Open SQL的部分 本文链接:http://www.cnblogs.com/hhelibe ...

随机推荐

  1. Go 数组(array) & 切片(slice)

    数组 数组是一组固定长度的序列 数组类型 数组的类型不仅和储存元素的类型有关,还和数组长度有关,不同长度的数组是不同的类型 不同类型的数组不能共用一个函数 func main() { var a [1 ...

  2. JQ的offset().top与JS的getBoundingClientRect区别详解,JS获取元素距离视窗顶部可变距离

     壹 ❀ 引 我在 JQ的offset().top与js的offsetTop区别详解 这篇博客中详细分析了JQ方法offset().top与JS属性offsetTop的区别,并得出了一条offset( ...

  3. Docker-Nginx,发布前端服务

    1.安装环境: yum install -y yum-utils \ device-mapper-persistent-data \ lvm2 yum-config-manager \ --add-r ...

  4. Node.js module export async function

    一.Demo 1.首先定义 module 文件:bbb.js const fs = require("fs"); function readFileSync() { let res ...

  5. 弹指间,网页灰飞烟灭——Google灭霸彩蛋实现

    不知道大家有没有看这段时间最火的一部电影<复仇者联盟4:终局之战>,作为漫威迷的我还没看,为什么呢?因为太贵了,刚上映的那周,一张IMAX厅的票价已经达到了299的天价,作为搬砖民工是舍不 ...

  6. JAVAEE学期总结

         声明:除第一张思维导图为博主所制作,其他思维导图皆来自网络,若侵权,望告知,必删除.                                                      ...

  7. Winform中封装DevExpress的MarqueeProgressBarComtrol实现弹窗式进度条效果

    场景 在Winform中实现弹窗式进度条 就是新建一个窗体,然后在窗体中加入进度条控件,然后在触发进度条的事件中将加载进度报告给 进度条控件. 注: 博客主页: https://blog.csdn.n ...

  8. 微服务与Spring Cloud基本概念、Spring Cloud版本命名方式与版本选择

    微服务是什么?Spring Cloud是什么?Spring Cloud版本命名方式?Spring Cloud版本选择? 一.微服务是什么 微服务是一种架构风格,是一种将单体应用开发为一组小型服务的方法 ...

  9. linux学习(五)用户与组管理命令,以及用户信息文件解释

    目录 (1)/etc/passwd文件 (2)/etc/shadow passwd命令 userdel命令 usermod命令 groupadd @(用户与组管理命令) linux是一个多用户多任务的 ...

  10. fastadmin中js是如何调用的

    想要了解fastadmin中的js是怎么调用的,就应该先了解RequireJs. RequireJs是模块化工具,每一个我们自己的js文件或者库都可以看成是一个模块,按需引入.写法如下: <sc ...