OO实现ALV TABLE 七:ALV的选择功能
在ALV的输出结果中,要对它的某一行、某一列或者某一单元格进行选定,我们通常的做法是把鼠标直接点击那一行或者是列就可以了,如果选择多行或多列,在选择的条件按住‘CTRL’键就可以了。这是手动选择的方法,但是在实际情况中,有时候需要用程序来对输出结果进行选择。
1. 首先我们要取得类CL_SALV_SELECTIONS的实例。
DATA lr_selectionsTYPE REF TO cl_salv_selections.
lr_selections = gr_table->get_selections( ).
2. 设置选择模式。
lr_selections->set_selection_mode(if_salv_c_selection_mode=>row_column ).
3. 选择行
DATA lt_row TYPE salv_t_row.
APPEND 3 TO lt_row.
APPEND 4 TO lt_row.
lr_selections->set_selected_rows( lt_row ).
4. 选择列
DATA lt_column TYPEsalv_t_column.
APPEND 3 TO lt_row.
APPEND 4 TO lt_row.
lr_selections->set_selected_rows( lt_row ).
5. 选择一个单元格
DATA ls_cell TYPEsalv_s_cell.
ls_cell-row = 7.
ls_cell-columnname = 'CITYFROM'.
lr_selections->set_current_cell( ls_cell )
6. 选择多个单元格
DATA lt_cell TYPE salv_t_cell,
ls_cell TYPE salv_s_cell.
ls_cell-row = 5.
ls_cell-columnname = 'CITYFROM'.
APPEND ls_cell TO lt_cell.
ls_cell-row = 6.
ls_cell-columnname = 'CITYFROM'.
APPEND ls_cellTO lt_cell.
lr_selections->set_selected_cells( lt_cell ).
下面是效果图
下面是程序的所有代码:
REPORT y_xin_002.
*变量定义
TYPES: BEGIN OF gs_spfli,
mandt TYPE spfli-mandt,
carrid TYPE spfli-carrid,
connid TYPE spfli-connid,
countryfr TYPE spfli-countryfr,
cityfrom TYPE spfli-cityfrom,
airpfrom TYPE spfli-airpfrom,
countryto TYPE spfli-countryto,
cityto TYPE spfli-cityto,
airpto TYPE spfli-airpto,
fltime TYPE spfli-fltime,
deptime TYPE spfli-deptime,
arrtime TYPE spfli-arrtime,
distance TYPE spfli-distance,
distid TYPE spfli-distid,
fltype TYPE spfli-fltype,
period TYPE spfli-period,
END OF gs_spfli.
TYPES ty_spfli TYPE gs_spfli OCCURS 0.
DATA: gr_table TYPE REF TO cl_salv_table.
*----------------------------------------------------------------------*
* CLASS lcl_alv DEFINITION
*----------------------------------------------------------------------*
* ALV操作类(定义)
*----------------------------------------------------------------------*
CLASS lcl_alv DEFINITION.
PUBLIC SECTION.
METHODS: getdata "取得要显示的数据
RETURNING value(lt_tab) TYPEty_spfli,
alv_full "全屏Grid列表处理方法
IMPORTING value(lt_tab) TYPE ty_spfli,
main. "主方法
ENDCLASS. "lcl_alv DEFINITION
*----------------------------------------------------------------------*
* CLASS lcl_alv IMPLEMENTATION
*----------------------------------------------------------------------*
* ALV操作类(实现)
*----------------------------------------------------------------------*
CLASS lcl_alv IMPLEMENTATION.
*取得要显示的数据
METHOD getdata.
SELECT * INTO CORRESPONDING FIELDS OF TABLElt_tab FROM spfli.
ENDMETHOD. "getdata
*输出全屏网格列表的方法
METHOD alv_full.
DATA: lr_functions TYPE REF TO cl_salv_functions,
lr_selections TYPE REF TOcl_salv_selections,
lt_column TYPE salv_t_column,
lt_row TYPE salv_t_row,
lt_cell TYPE salv_t_cell,
ls_cell TYPE salv_s_cell.
"创建实例
TRY.
cl_salv_table=>factory(
IMPORTING
r_salv_table = gr_table
CHANGING
t_table = lt_tab
).
CATCH cx_salv_msg.
ENDTRY.
"显示ALV的标准功能
lr_functions = gr_table->get_functions().
lr_functions->set_all( 'X' ).
"取得类CL_SALV_SELECTIONS的实例
lr_selections =gr_table->get_selections( ).
"设置选择模式
lr_selections->set_selection_mode(if_salv_c_selection_mode=>row_column ).
"选择列
APPEND 'FLTIME' TO lt_column.
APPEND 'DISTANCE' TO lt_column.
lr_selections->set_selected_columns(lt_column ).
"选择行
APPEND 3 TO lt_row.
APPEND 4 TO lt_row.
lr_selections->set_selected_rows( lt_row).
* "选择多个单元格
* ls_cell-row = 5.
* ls_cell-columnname = 'CITYFROM'.
* APPEND ls_cell TO lt_cell.
* ls_cell-row = 6.
* ls_cell-columnname = 'CITYFROM'.
* APPEND ls_cell TO lt_cell.
* lr_selections->set_selected_cells(lt_cell ).
"选择一个单元格
ls_cell-row = 7.
ls_cell-columnname = 'CITYFROM'.
lr_selections->set_current_cell( ls_cell).
"显示列表
gr_table->display( ).
ENDMETHOD. "alv_full
*主方法,整合数据
METHOD main.
DATA: lt_tab TYPE ty_spfli.
"取得要显示的数据
lt_tab = me->getdata( ).
me->alv_full( lt_tab ).
ENDMETHOD. "main
ENDCLASS. "lcl_alvIMPLEMENTATION
*执行动作
START-OF-SELECTION.
DATA lr_alv TYPE REF TO lcl_alv.
CREATE OBJECT lr_alv.
lr_alv->main( ).
OO实现ALV TABLE 七:ALV的选择功能相关推荐
- WDA学习(9):Use an ALV TABLE in WDA
实例展示如何使用ALV TABLE在窗口显示航班信息. 1.创建Web Dynpro Component. 2.创建Component Usage,使用SALV_WD_TABLE组件 Context页 ...
- OO实现ALV TABLE 五:ALV的栏位属性
ALV的栏位属性是SAP提供的ALV功能的比较重要的一个,详细的功能包括异常状态图标.图标.符号.复选框.按钮.热点.超链接.单元格类型.单元格颜色.某一栏位颜色.某一行颜色,栏位隐藏等等.ALV的栏 ...
- OO实现ALV TABLE 一:最简单的ALV显示
以前都是通过函数"REUSE_ALV_GRID_DISPLAY"来显示列表,这种方式是面向过程的,现在有另外一种面向对象化的方式来显示列表,函数REUSE_ALV_GRID_DIS ...
- OO实现ALV TABLE 二:ALV显示的三种形式
一般的ALV有三种显示形式,分别为 一.普通的List 二.全屏的Grid 三.在自定义屏幕的显示的Grid 跟以往实现这三种ALV显示方式相比,以往的三种显示方式分别是调用不同的Function和C ...
- OO实现ALV TABLE 三:ALV的功能设计
细心的读者肯定已经注意前面的两个例子少了点什么,少了ALV提供的标准功能,比如排序,过滤,汇总,等,以及用户可以在ALV的功能栏上加上自己自定义的功能按钮. ALV的标准功能可以通过类CL_SALV_ ...
- OO实现ALV TABLE 四:ALV的显示样式
通过类CL_SALV_DISPLAY_SETTINGS我们可以设置ALV的显示样式,主要包括ALV表头名称,列表颜色间隔显示,水平线是否显示,竖线是否显示等. 1.首先我们要取得类CL_SALV_DI ...
- OO ALV 实现方式 ALV TABLE 之 栏位属性
REPORT zalv01. *变量定义 INCLUDE <icon>. INCLUDE <symbol>. TYPES: BEGIN OF gs_spfli, ...
- OO实现ALV TABLE 六:ALV的弹出窗口形式
前面的例子ALV列表都是直接输出在主窗口中,下面我们实现在弹出窗口中实现ALV.在弹出窗口中实现ALV也很简单,只要在实现类CL_SALV_TABLE的一个方法SET_SCREEN_POPUP就可以了 ...
- OO实现ALV TABLE 八:ALV的布局功能
在ALV的输出结果中,我们可以利用ALV提供的标准功能(过滤,排序,汇总)对输出结果正行操作.比如说我们对一个结果进行了排序和过滤等的动作,下次再运行这个报表的时候可以选择一个功能直接运行这些动作.这 ...
最新文章
- 【性格心理学】为什么我在关键时刻总是紧张?
- debian8下给postgresql9.5编译配置pgpool-II-3.5
- swift语言注册非免费苹果账号iOS游戏框架Sprite Kit基础教程
- HTMLTestRunner加入logging输出
- 用python计算两个二维list依据第二维的前一个数据相加
- how does SAP CRM partner function work - how is account change working
- 2020-06-24 电子书网站http://www.itjiaocheng.com/mianfei/
- 怎样做计算机系统的镜像文件,Windows7 镜像制作过程 图文说明
- 京东自动化签到脚本-京东休闲游戏自动化签到助手
- iTextSharp生成pdf文档案例
- Duplicate Cleaner Pro v5.0.13 电脑重复文件查找清理工具
- Laravel学习笔记(8)利用SEEDER或者模型工厂批量导入数据
- 用月壤实现太阳能发电,人类离「定居月球」又近一步 | 来自贝索斯蓝色起源...
- 去除眼袋(画笔涂抹法)
- 如何修改命令提示符(cmd)的颜色?
- matplotlib数据可视化实验报告1(最终版)
- 华为手机怎么使用分屏_这是一份华为手机必备小技巧使用说明
- ShardingSphere5.1.0 +JPA的分表配置
- 全球与中国高尔夫旅游市场现状及未来发展趋势
- 交通·未来第2期:深度交通感知: 从区域流量预测到在线OD预测