接上篇

一开始设计的BO 类是为了实现功能而实现功能

从类的单一职责的角度而言

先把这个BO对象拆分

 

这里又有一个需要考虑的点:   如何传递内表数据到ALV

如果引入一个中间变量,数据就会被double

alv大量数据显示也是常有的事,再double一下显然不可取

而且alv中修改了数据还得把修改的数据传回去  想想就麻烦

于是就想到了引用类型,这是个不错的解决方案

 

后来又反思了一下,

是否真的需要引用类型,是否有必要遵守严格的OO属性不对外公开

从写代码更简单,更快交付而言

在这个模型中把 要显示的内表声明为public 似乎更好一点

 

CLASS lcl_bo DEFINITION.
PUBLIC SECTION.
METHODS:
mock."模拟业务操作
DATA:
gt_bo TYPE tt_bo.
ENDCLASS. CLASS lcl_alv DEFINITION.
PUBLIC SECTION.
METHODS:
config," alv 显示参数
display CHANGING ct_table TYPE ANY TABLE."alv *
PRIVATE SECTION.
DATA:
gt_fieldcat TYPE lvc_t_fcat," 显示字段列表
gs_layout TYPE lvc_s_layo , " 页面布局
g_container TYPE REF TO cl_gui_custom_container, " 容器
g_grid TYPE REF TO cl_gui_alv_grid. " 显示Grid ENDCLASS. CLASS lcl_bo IMPLEMENTATION.
METHOD mock.
DATA: ls_bo TYPE ts_bo.
DO 10 TIMES.
ls_bo-datum = sy-datum + sy-index.
ls_bo-uzeit = sy-uzeit.
ls_bo-value = 'Times:' && sy-index.
APPEND ls_bo TO gt_bo.CLEAR ls_bo.
ENDDO.
ENDMETHOD. ENDCLASS. CLASS lcl_alv IMPLEMENTATION. METHOD config.
DATA:
ls_fieldcat TYPE lvc_s_fcat.
ls_fieldcat-fieldname = 'DATUM'.ls_fieldcat-coltext = '日期'. APPEND ls_fieldcat TO gt_fieldcat.CLEAR ls_fieldcat.
ls_fieldcat-fieldname = 'UZEIT'.ls_fieldcat-coltext = '时间'. APPEND ls_fieldcat TO gt_fieldcat.CLEAR ls_fieldcat.
ls_fieldcat-fieldname = 'VALUE'.ls_fieldcat-coltext = '内容'. APPEND ls_fieldcat TO gt_fieldcat.CLEAR ls_fieldcat. gs_layout-sel_mode = 'A'.
gs_layout-zebra = 'X' .
gs_layout-cwidth_opt = 'X'.
ENDMETHOD. METHOD display.
IF g_grid IS INITIAL.
CREATE OBJECT g_container
EXPORTING
container_name = 'C0100'. CREATE OBJECT g_grid
EXPORTING
i_parent = g_container. CALL METHOD g_grid->set_table_for_first_display
EXPORTING
* I_BUFFER_ACTIVE =
* I_CONSISTENCY_CHECK =
* I_STRUCTURE_NAME =
* is_variant = gs_variant
i_save = 'A'
i_default = 'X'
* is_layout = gs_layout
* IS_PRINT =
* IT_SPECIAL_GROUPS =
* it_toolbar_excluding = gt_exclude
* IT_HYPERLINK =
CHANGING
it_outtab = ct_table
it_fieldcatalog = gt_fieldcat
* it_sort = gt_sort
* IT_FILTER =
EXCEPTIONS
invalid_parameter_combination = 1
program_error = 2
too_many_lines = 3
OTHERS = 4.
ELSE.
CALL METHOD g_grid->refresh_table_display.
ENDIF. ENDMETHOD. "display ENDCLASS. DATA:
ok_code TYPE sy-ucomm,
go_bo TYPE REF TO lcl_bo,
go_alv TYPE REF TO lcl_alv. START-OF-SELECTION.
CREATE OBJECT go_bo.
CREATE OBJECT go_alv.
go_bo->mock( ).
go_alv->config( ).
CALL SCREEN 100. MODULE status_0100 OUTPUT.
SET PF-STATUS 'PS100'.
go_alv->display( CHANGING ct_table = go_bo->gt_bo ).
ENDMODULE. " STATUS_0100 OUTPUT MODULE user_command_0100 INPUT.
CASE ok_code.
WHEN 'BACK'.
SET SCREEN 0.
ENDCASE.
ENDMODULE. " USER_COMMAND_0100 INPUT

效果如下:

 

这个模型应该比上一个要好一点

BO中只关注业务逻辑,怎么显示全部交给ALV

 

如果严格的说遵循一些OO的编程规范

gt_bo是不可以放在public sction中的

那么传递数据使用需要稍微作一个变化

bo对象增加一个get_ref_table的方法

返回引用,对应的alv的display方法传入引用类型参数

代码就不写了

(在后续会讨论重用ALV对象

如果采用引用传递的话还有一个变化

定义一个通用接口 ,接口中就一个方法获取输出内表的引用

BO对象都要实现这个接口

ALV的display方法传入的参数就是这个接口对象)

 

* 这篇文章也是在上线期间事情不多的时候陆陆续续写的

* 又开始忙起来了,之后更新的速度可能就慢了(或者说又开始懒了)

* 大致把后续的思路也说一下吧

 

在当前模式下

一个BO  对应一个ALV

一般复杂一点的报表会有多个BO

也就有多个ALV

很自然会发现ALV的部分代码都是重复的

 

后续会讨论用抽象类实现ALV的基本功能

子类只关注fieldcat的编码

以及如何扩展抽象类的功能

使其适应项目中不同场景的要求

例如,隐藏工具栏,增加输出列,保持选中,启用变式等等

以及如何适应未来没有考虑到的扩展场景(其实就是预留一些方法,给子类重写而已)

当做到这一步的时候

其实会发现SAP已经帮我们都把这些事情做得差不多了

把我们的OO代码 同SAP的 REUSE_ALV_GRID_DISPLAY 结合

就是目前一直在做的事情

 

但是自定义的ALV有一个好处

可以把这个模型用到复杂的对话屏幕中

除了ALV还有其他控件 

所以自定义的ALV还是有用武之地的

如果单纯的做报表

那么推荐 OO + REUSE_ALV_GRID_DISPLAY

OO的代码处理核心业务逻辑

(还可以引入一些简单的设计模式,报表开发就会很happy~)

同时自定义的控件中封装REUSE_ALV_GRID_DISPLAY  显示也变得很简单

 

后续还会再写几个不同场景的示例出来

都是个人的一些思路,欢迎交流.

待续吧…

ABAP OO与ALV结合方式探索(2)的更多相关文章

  1. ABAP OO与ALV结合方式探索(1)

    用OO来开发,尤其是在复杂业务的开发过程中 从程序设计的角度而言,应该更简单一点 而ALV是二次开发中登场很高的一个控件 最近做了一些尝试,探索OO的代码和ALV的结合使用   使用控件型的ALV A ...

  2. ABAP OO的八大理由

    原贴地址:http://scnblogs.techweb.com.cn/abaplv/archives/127.html 几年前SAP BASIS 4.6为ABAP扩展了OO功能,这是很多传统的ABA ...

  3. OO的ALV隐藏工具栏的form

    OO的ALV隐藏工具栏: ***展示数据 CALL METHOD gr_alvgrid->set_table_for_first_display EXPORTING is_variant = g ...

  4. 通过接口标准化ABAP OO开发

    本文是对接口编程的讨论,希望能对年轻的开发者有所帮助. 要点: 通过接口对类方法进行更高层的抽象 接口使代码清晰易读 接口使你可以创建模拟对象(Mockup Object)以提高代码的可测试性 帮助实 ...

  5. ABAP分享二 ALV标准范例DEMO汇总

    SAP软件针对ALV的使用方法,提供了ALV标准demo程序: sap提供的ALV标准demo程序,只是展示简单的数据,用function ALV即可,若有复杂的增删改查操作 建议使用OO ALV,下 ...

  6. ABAP OO 开发语法整理

    [转自 http://blog.csdn.net/saphome/article/details/6956933] 在类中,只能用TYPE 附加关键字指定数据类型. •TYPES: 一般的类型定义方法 ...

  7. ABAP分享六 alv显示的几种方式的简单示例

    方法1,也是大家常见的方法通过函数   REUSE_ALV_GRID_DISPLAY TYPES: BEGIN OF  ty_spfli,   "定义结构     carrid like s ...

  8. ABAP分享五 ALV修改单元格并将修改数据更新到数据表中示例1

    *下面的代码是在alv字段中修改字段的内容,点击保存后就可以保存数据至数据表. TABLES: spfli. DATA: wa_fieldcat TYPE lvc_s_fcat ,  " 相 ...

  9. OO ALV 学习参考

      http://blog.csdn.net/sapliumeng/article/details/18653491 一.ALV介绍 The ALV Grid Control (ALV = SAPLi ...

随机推荐

  1. QT 操作数据库

    整理一下 QT 操作数据库的一些要点,以备以后的查询学习(主要是操作 mysql ). 首先,要查询相关的驱动是否已经装好了,可以用以下的程序进行验证: #include <QtCore/QCo ...

  2. java中静态的代码块,静态变量,静态方法

    简单了解一下java虚拟机--jvm几个内存区域: 方法区:在java的虚拟机中有一块专门用来存放已经加载的类信息.常量.静态变量以及方法代码的内存区域, 常量池:常量池是方法区的一部分,主要用来存放 ...

  3. IOS开发之路三(XML解析之KissXML的使用)

    最近再做一个项目需要用到xml的解析.今天查了一些资料自己做了一个小demo.纯OC没有界面.. 在IOS平台上进行XML文档的解析有很多种方法,在SDK里面有自带的解析方法,但是大多情况下都倾向于用 ...

  4. 如何在Linux下拷贝一个目录呢

    cp -af newadmin/movie/.   uploadfile/mallvideo/ 如何在Linux下拷贝一个目录呢?这好像是再简单不过的问题了. 比如要把/home/usera拷贝到/m ...

  5. docker 中运行 sshd 服务

    创建Dockerfile # sshd # # VERSION 0.0.2 FROM ubuntu:14.04 MAINTAINER admln <admln@docker.com> RU ...

  6. Aggressive cows 二分不仅仅是查找

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7083   Accepted: 3522 Description Farme ...

  7. 开启AsyncTask从网络加载图片

    /*AsyncTask 异步任务即做一些简单的异步处理 :是handle与线程池的封装 * 第一个泛型:参数类型泛型 * 第二个泛型:更新进度泛型 * 第三个泛型:onProgressUpdate的返 ...

  8. 【Shell脚本学习17】Shell case esac语句

    case ... esac 与其他语言中的 switch ... case 语句类似,是一种多分枝选择结构. case 语句匹配一个值或一个模式,如果匹配成功,执行相匹配的命令.case语句格式如下: ...

  9. OC之category的用法

    简介 实例 好处 一.category简介 动态的为某个已经存在的类增加方法,不可以增加成员变量 二.实例 // // Student+CatetoryStudent.h // Category // ...

  10. Unity封装dll教程整理

    ///作者Unity3d师兄---LeroyYang 通过网上大神们的资料以及自己的整理,学习一下用vs2013简单的封装dll文件,方便接口模式下开发,使得逻辑层更为清晰. 操作步骤 1.打开vs2 ...