SAP web 开发 (第二篇 bsp 开发 mvc模式 Part2 )
单击第一个图标,第一个图标突出显示,单击第二个图标,第一个变灰,第二个突出显示,反之一样。单击history读取历史记录。
Controller ZCL_SUS_C_ORDER_CHANGE
- 1. DO_INIT
method DO_INIT.
*CALL METHOD SUPER->DO_INIT
* .
if ZORDERCHANGEMODEL is initial.
create object ZORDERCHANGEMODEL.
select * from usr02 into corresponding fields of table ZORDERCHANGEMODEL->ORDERCHANGE up to 5 rows.
field-symbols <usr_tab> like line of ZORDERCHANGEMODEL->ORDERCHANGE.
loop at ZORDERCHANGEMODEL->ORDERCHANGE assigning <usr_tab>.
<usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok-grau.gif'.
<usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel-grau.gif'.
endloop.
append initial line to ZORDERCHANGEMODEL->ORDERCHANGE_history.
append initial line to ZORDERCHANGEMODEL->ORDERCHANGE_history.
append initial line to ZORDERCHANGEMODEL->ORDERCHANGE_history.
append initial line to ZORDERCHANGEMODEL->ORDERCHANGE_history.
append initial line to ZORDERCHANGEMODEL->ORDERCHANGE_history.
loop at ZORDERCHANGEMODEL->ORDERCHANGE_history assigning <usr_tab>.
<usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok-grau.gif'.
<usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel-grau.gif'.
<usr_tab>-bname = 'history'.
endloop.
create object ZORDERCHANGEMODEL->io_iterator.
ZORDERCHANGEMODEL->io_iterator->request = request.
endif.
endmethod.
- 2. DO_REQUEST
method DO_REQUEST.
*CALL METHOD SUPER->DO_REQUEST
* .
me->DISPATCH_INPUT( ).
data: lo_view type ref to if_bsp_page.
lo_view = create_view( view_name = '../order/order_change_response.inc' ).
lo_view->set_attribute( name = 'zmodel' value = ZORDERCHANGEMODEL ).
call_view( lo_view ).
endmethod.
- 3. DO_HANDLE_EVENT
method DO_HANDLE_EVENT.
*CALL METHOD SUPER->DO_HANDLE_EVENT
* EXPORTING
* EVENT =
* HTMLB_EVENT =
** HTMLB_EVENT_EX =
* GLOBAL_MESSAGES =
* RECEIVING
* GLOBAL_EVENT =
* .
data lr_tableview type ref to CL_HTMLB_TABLEVIEW.
lr_tableview ?= cl_htmlb_manager=>get_data(
request = me->request
id = 'zorder.cuschanged_t2'
name = 'tableView' ).
IF NOT LR_TABLEVIEW IS INITIAL.
IF LR_TABLEVIEW->DATA->SERVER_EVENT = 'onCellClick'
AND LR_TABLEVIEW->DATA->ID = 'zorder.cuschanged_t2'
AND LR_TABLEVIEW->DATA->NAME = 'tableView'
AND LR_TABLEVIEW->DATA->COLUMN_KEY = 'ICONS'
AND LR_TABLEVIEW->DATA->COLUMN_INDEX > 0
AND LR_TABLEVIEW->DATA->ROW_INDEX > 0.
field-symbols: <usr_tab> type zusr02,
<usr_cancel> type zusr02.
data usr_tab type zusr02.
IF ZORDERCHANGEMODEL->HISTORY_SHOW = ''.
read table ZORDERCHANGEMODEL->ORDERCHANGE index LR_TABLEVIEW->DATA->ROW_INDEX assigning <usr_tab>.
ELSE.
read table ZORDERCHANGEMODEL->ORDERCHANGE_history index LR_TABLEVIEW->DATA->ROW_INDEX assigning <usr_tab>.
endif.
if <usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok.gif'.
<usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok-grau.gif'.
else.
<usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok.gif'.
<usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel-grau.gif'.
endif.
ENDIF.
IF LR_TABLEVIEW->DATA->SERVER_EVENT = 'onCellClick'
AND LR_TABLEVIEW->DATA->ID = 'zorder.cuschanged_t2'
AND LR_TABLEVIEW->DATA->NAME = 'tableView'
AND LR_TABLEVIEW->DATA->COLUMN_KEY = 'CANCEL'
AND LR_TABLEVIEW->DATA->COLUMN_INDEX > 0
AND LR_TABLEVIEW->DATA->ROW_INDEX > 0.
IF ZORDERCHANGEMODEL->HISTORY_SHOW = ''.
read table ZORDERCHANGEMODEL->ORDERCHANGE index LR_TABLEVIEW->DATA->ROW_INDEX assigning <usr_tab>.
ELSE.
read table ZORDERCHANGEMODEL->ORDERCHANGE_history index LR_TABLEVIEW->DATA->ROW_INDEX assigning <usr_tab>.
endif.
if <usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel.gif'.
<usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel-grau.gif'.
else.
<usr_tab>-cancel = '/sap/bc/bsp/sap/srmsus/images/order/cancel.gif'.
<usr_tab>-icons = '/sap/bc/bsp/sap/srmsus/images/order/ok-grau.gif'.
endif.
endif.
ENDIF.
if not htmlb_event is initial.
if HTMLB_EVENT->SERVER_EVENT = 'onhistoryclick'.
ZORDERCHANGEMODEL->HISTORY_SHOW = 'X'.
elseif HTMLB_EVENT->SERVER_EVENT = 'onprocessclick'.
ZORDERCHANGEMODEL->HISTORY_SHOW = ''.
endif.
endif.
endmethod.
- 4. View
<%@page language="abap" otrTrim="true" %>
<%@extension name="htmlb" prefix="htmlb" %>
<%@extension name="SRMSUS" prefix="sus" %>
<%@extension name="xhtmlb" prefix="xhtmlb" %>
<%
INCLUDE bbp_sus_ui_const.
%>
<!-- messages controller -->
<%@include file="framework/carrier_view_message.inc" %>
<htmlb:tray id = "orderchange"
title = "Order Change Response"
width = "100%">
<htmlb:gridLayout id = "GR_RPT_Query"
rowSize = "3"
columnSize = "1"
cellSpacing = "10"
width = "100%">
<htmlb:gridLayoutCell rowIndex = "1"
columnIndex = "1"
width = "100%" >
<% if zmodel->history_show <> 'X'. %>
<td align = "right">
<htmlb:link id="history"
text="history"
onClick="onhistoryclick"
></htmlb:link>
</td>
<% else. %>
<td align = "right">
<htmlb:link id="inprocess"
text="inprocess"
onClick="onprocessclick"
></htmlb:link>
</td>
<% endif.%>.
</htmlb:gridLayoutCell>
<htmlb:gridLayoutCell rowIndex = "2"
columnIndex = "1"
width = "100%" >
<% if zmodel->history_show <> 'X'. %>
<htmlb:tableView id="t2"
emptyTableText = "<%= otr(BBP_SUS_UI/LIST_ORDER_NO_ENTRIES_FOUND) %>"
sort = "SERVER"
onHeaderClick = "onmyHeaderClick"
onNavigate = "onMyNavigate"
onRowSelection = "onMyRowSelection"
visibleRowCount = "10"
visibleFirstRow = "1"
iterator = "<%=zmodel->io_iterator%>"
table="//zmodel/ORDERCHANGE">
<htmlb:tableViewColumn columnName="ICONS"
onCellClick="onCellClick"
width="5"
></htmlb:tableViewColumn>
<htmlb:tableViewColumn columnName="CANCEL"
onCellClick="onCellClick"
width="5"
></htmlb:tableViewColumn>
<htmlb:tableViewColumn columnName="BNAME"
onCellClick="onCellClick"
title="BNAME"
></htmlb:tableViewColumn>
</htmlb:tableView>
<% else. %>
<htmlb:tableView id="t2"
emptyTableText = "<%= otr(BBP_SUS_UI/LIST_ORDER_NO_ENTRIES_FOUND) %>"
sort = "SERVER"
onHeaderClick = "onmyHeaderClick"
onNavigate = "onMyNavigate"
onRowSelection = "onMyRowSelection"
visibleRowCount = "10"
visibleFirstRow = "1"
iterator = "<%=zmodel->io_iterator%>"
table="//zmodel/ORDERCHANGE_HISTORY">
<htmlb:tableViewColumn columnName="ICONS"
onCellClick="onCellClick"
width="5"
></htmlb:tableViewColumn>
<htmlb:tableViewColumn columnName="CANCEL"
onCellClick="onCellClick"
width="5"
></htmlb:tableViewColumn>
<htmlb:tableViewColumn columnName="BNAME"
onCellClick="onCellClick"
title="BNAME"
></htmlb:tableViewColumn>
</htmlb:tableView>
<% endif.%>.
</htmlb:gridLayoutCell>
<htmlb:gridLayoutCell rowIndex = "3"
columnIndex = "1"
width = "100%" >
<htmlb:button id="update"
text = "Update"
onClick = "onupdateclick"
/>
</htmlb:gridLayoutCell>
</htmlb:gridLayout>
</htmlb:tray>
- 5. Page attributes
zmodel TYPE REF TO ZCL_SUS_C_ORDER_CHANGE_MODEL
- 6. Controller attributes
ZORDERCHANGEMODEL Instance Attribute Public Type Ref ToZCL_SUS_C_ORDER_CHANGE_MODEL
HISTORY_SHOW Instance Attribute Public Type CHAR1
- 7. Model ZCL_SUS_C_ORDER_CHANGE_MODEL
Attributes:
ORDERCHANGE Instance Attribute Public Type ZTESTUSR01
IO_ITERATOR Instance Attribute Public Type Ref To ZCL_SUS_C_ORD_C_ITERATOR
ORDERCHANGE_HISTORY Instance Attribute Public Type ZTESTUSR01
HISTORY_SHOW Instance Attribute Public Type CHAR1
- 8. ITERATOR ZCL_SUS_C_ORD_C_ITERATOR
Interface IF_HTMLB_TABLEVIEW_ITERATOR
Attributes:
M_ROW_REF Instance Attribute Public Type Ref To ZUSR02
REQUEST Instance Attribute Public Type Ref To IF_HTTP_REQUEST
method IF_HTMLB_TABLEVIEW_ITERATOR~RENDER_ROW_START.
m_row_ref ?= p_row_data_ref.
endmethod.
method IF_HTMLB_TABLEVIEW_ITERATOR~RENDER_CELL_START.
data lr_tableview type ref to CL_HTMLB_TABLEVIEW.
* lr_tableview ?= cl_htmlb_manager=>get_data(
* request = request
* id = 't2'
* name = 'tableView' ).
field-symbols <icons_name> type char50.
field-symbols:
<ls_data> type any,
<ls_icons> type any,
<ls_kyfs> type any.
DATA: icon_plane TYPE STRING.
CASE p_column_key.
WHEN 'CANCEL'.
ASSIGN P_ROW_DATA_REF->* to <ls_data>.
assign component 'CANCEL' of structure <ls_data> TO <ls_icons>.
icon_plane = <ls_icons>.
p_replacement_bee = CL_HTMLB_IMAGE=>FACTORY( id = p_cell_id src = icon_plane ).
WHEN 'ICONS'.
ASSIGN P_ROW_DATA_REF->* to <ls_data>.
assign component 'ICONS' of structure <ls_data> TO <ls_icons>.
icon_plane = <ls_icons>.
p_replacement_bee = CL_HTMLB_IMAGE=>FACTORY( id = p_cell_id src = icon_plane ).
WHEN 'BNAME'.
ASSIGN P_ROW_DATA_REF->* to <ls_data>.
assign component 'BNAME' of structure <ls_data> TO <ls_icons>.
icon_plane = <ls_icons>.
p_replacement_bee = CL_HTMLB_TEXTVIEW=>FACTORY( id = p_cell_id text = icon_plane ).
ENDCASE.
endmethod.
转:http://blog.chinaunix.net/uid-465882-id-2115966.html
SAP web 开发 (第二篇 bsp 开发 mvc模式 Part2 )的更多相关文章
- SAP web 开发 (第二篇 bsp 开发 mvc模式 Part1 )
Model-View-Controller 简称MVC. 简单的说就是把数据处理,显示,页面事件及处理过程分离开来,企业应用多数都采用这种方式,多层架构的优缺点不再多言,google一下啥都知道. 在 ...
- 第二篇 界面开发 (Android学习笔记)
第二篇 界面开发 第5章 探索界面UI元素 ●The Android View Class ●△Widget设计步骤 需要修改三个XML,以及一个class: 1)第一个xml是布局XML文件 ...
- iOS开发——高级技术精选&底层开发之越狱开发第二篇
底层开发之越狱开发第二篇 今天项目中要用到检查iPhone是否越狱的方法. Umeng统计的Mobclick.h里面已经包含了越狱检测的代码,可以直接使用 /*方法名: * isJailbroken ...
- iOS开发UI篇—iOS开发中三种简单的动画设置
iOS开发UI篇—iOS开发中三种简单的动画设置 [在ios开发中,动画是廉价的] 一.首尾式动画 代码示例: // beginAnimations表示此后的代码要“参与到”动画中 [UIView b ...
- iOS开发UI篇—IOS开发中Xcode的一些使用技巧
iOS开发UI篇—IOS开发中Xcode的一些使用技巧 一.快捷键的使用 经常用到的快捷键如下: 新建 shift + cmd + n 新建项目 cmd + n 新建文 ...
- iOS开发UI篇—iPad开发中得modal介绍
iOS开发UI篇—iPad开发中得modal介绍 一.简单介绍 说明1: 在iPhone开发中,Modal是一种常见的切换控制器的方式 默认是从屏幕底部往上弹出,直到完全盖住后面的内容为止 说明2: ...
- android 串口开发第二篇:利用jni实现android和串口通信
一:串口通信简介 由于串口开发涉及到jni,所以开发环境需要支持ndk开发,如果未配置ndk配置的朋友,或者对jni不熟悉的朋友,请查看上一篇文章,android 串口开发第一篇:搭建ndk开发环境以 ...
- Web开发的分层结构与MVC模式
1.分层结构 所谓分层结构.把不同的功能代码封装成类,把相同功能的类封装在一个个的包中,也叫层.功能归类如下: 实体类: 封装数据,是数据的载体,在层与层之间进行传递,数据也就传递了.比如说要传递学生 ...
- 微信支付之JSAPI开发-第二篇:业务流程详解与方案设计
微信支付流程 流程: 上图的网址为:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_4 如上图所示,微信网页支付的具体流程大致分为 ...
随机推荐
- Unix/Linux编程实践教程(0:文件、终端、信号)
本来只打算读这本书socket等相关内容,但书写得实在好,还是决定把其余的内容都读一下. 阅读联机帮助的一个示例: open系统调用: read系统调用: Unix的time: 上面的printf可以 ...
- CentOS7安装Nginx-1.9.9+PHP5.6
linux系统CentOS7 Nginx 下载地址http://nginx.org/en/download.html wget下载路径http://nginx.org/download/nginx-1 ...
- SOAP和WSDL的一些必要知识
SOAP和WSDL对Web Service.WCF进行深入了解的基础,因此花一些时间去了解一下是很有必要的. 一.SOAP(Simple Object Access Protocol) 如果我们要调用 ...
- <转>linux crontab 定时任务
基本格式 : * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用*或者 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 ...
- 从零开始学习jQuery(转)
本系列文章导航 从零开始学习jQuery (一) 开天辟地入门篇 从零开始学习jQuery (二) 万能的选择器 从零开始学习jQuery (三) 管理jQuery包装集 从零开始学习jQuery ( ...
- WSDL2ObjC Unsupported Media Type
调用WCF服务时,出这样的异常“415 Unsupported Media Type”, Because the WCF soap is v1.1, the http header should be ...
- <开心一笑> 前端工程师你们伤不起!
前端工程师你们伤不起!! 来自: 刻铭 2011-03-11 14:09:53 前端工程师伤不起 老子几年前进了互联网圈!!!!!!!成了前端工程师,名字是不是很拉风,有木有!!!!!!!! 尼玛 ...
- 分部类(partial)
一般来说,一个类.结构或接口位于一个源文件中,但某些情况,比如大型项目.特殊部署时,可能需要把一个类.结构或接口放在几个文件中来处理.等到编译时,自动把它们合起来,这就得应用 C# 分部类了. C# ...
- js 过滤script
function stripscript(s) { return s.replace(/<script.*?>.*?<\/script>/ig, ''); } 稍微 ...
- Head First 设计模式--2 观察者模式 解耦
观察者模式定义了对象之间一对多的依赖,这样依赖,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. 假如有这么一个项目,监控每天的天气状况WeatherData(温度,湿度,气压).有布告板 ...