在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的选择功能相关推荐

  1. WDA学习(9):Use an ALV TABLE in WDA

    实例展示如何使用ALV TABLE在窗口显示航班信息. 1.创建Web Dynpro Component. 2.创建Component Usage,使用SALV_WD_TABLE组件 Context页 ...

  2. OO实现ALV TABLE 五:ALV的栏位属性

    ALV的栏位属性是SAP提供的ALV功能的比较重要的一个,详细的功能包括异常状态图标.图标.符号.复选框.按钮.热点.超链接.单元格类型.单元格颜色.某一栏位颜色.某一行颜色,栏位隐藏等等.ALV的栏 ...

  3. OO实现ALV TABLE 一:最简单的ALV显示

    以前都是通过函数"REUSE_ALV_GRID_DISPLAY"来显示列表,这种方式是面向过程的,现在有另外一种面向对象化的方式来显示列表,函数REUSE_ALV_GRID_DIS ...

  4. OO实现ALV TABLE 二:ALV显示的三种形式

    一般的ALV有三种显示形式,分别为 一.普通的List 二.全屏的Grid 三.在自定义屏幕的显示的Grid 跟以往实现这三种ALV显示方式相比,以往的三种显示方式分别是调用不同的Function和C ...

  5. OO实现ALV TABLE 三:ALV的功能设计

    细心的读者肯定已经注意前面的两个例子少了点什么,少了ALV提供的标准功能,比如排序,过滤,汇总,等,以及用户可以在ALV的功能栏上加上自己自定义的功能按钮. ALV的标准功能可以通过类CL_SALV_ ...

  6. OO实现ALV TABLE 四:ALV的显示样式

    通过类CL_SALV_DISPLAY_SETTINGS我们可以设置ALV的显示样式,主要包括ALV表头名称,列表颜色间隔显示,水平线是否显示,竖线是否显示等. 1.首先我们要取得类CL_SALV_DI ...

  7. OO ALV 实现方式 ALV TABLE 之 栏位属性

    REPORT  zalv01. *变量定义 INCLUDE <icon>. INCLUDE <symbol>. TYPES: BEGIN OF gs_spfli,        ...

  8. OO实现ALV TABLE 六:ALV的弹出窗口形式

    前面的例子ALV列表都是直接输出在主窗口中,下面我们实现在弹出窗口中实现ALV.在弹出窗口中实现ALV也很简单,只要在实现类CL_SALV_TABLE的一个方法SET_SCREEN_POPUP就可以了 ...

  9. OO实现ALV TABLE 八:ALV的布局功能

    在ALV的输出结果中,我们可以利用ALV提供的标准功能(过滤,排序,汇总)对输出结果正行操作.比如说我们对一个结果进行了排序和过滤等的动作,下次再运行这个报表的时候可以选择一个功能直接运行这些动作.这 ...

最新文章

  1. 【性格心理学】为什么我在关键时刻总是紧张?
  2. debian8下给postgresql9.5编译配置pgpool-II-3.5
  3. swift语言注册非免费苹果账号iOS游戏框架Sprite Kit基础教程
  4. HTMLTestRunner加入logging输出
  5. 用python计算两个二维list依据第二维的前一个数据相加
  6. how does SAP CRM partner function work - how is account change working
  7. 2020-06-24 电子书网站http://www.itjiaocheng.com/mianfei/
  8. 怎样做计算机系统的镜像文件,Windows7 镜像制作过程 图文说明
  9. 京东自动化签到脚本-京东休闲游戏自动化签到助手
  10. iTextSharp生成pdf文档案例
  11. Duplicate Cleaner Pro v5.0.13 电脑重复文件查找清理工具
  12. Laravel学习笔记(8)利用SEEDER或者模型工厂批量导入数据
  13. 用月壤实现太阳能发电,人类离「定居月球」又近一步 | 来自贝索斯蓝色起源...
  14. 去除眼袋(画笔涂抹法)
  15. 如何修改命令提示符(cmd)的颜色?
  16. matplotlib数据可视化实验报告1(最终版)
  17. 华为手机怎么使用分屏_这是一份华为手机必备小技巧使用说明
  18. ShardingSphere5.1.0 +JPA的分表配置
  19. 全球与中国高尔夫旅游市场现状及未来发展趋势
  20. 交通·未来第2期:深度交通感知: 从区域流量预测到在线OD预测

热门文章

  1. 解决标签回车后产生的空格
  2. Android adb命令,linux中各种命令
  3. Java基础班学习笔记(6)
  4. [原]Android打包之Gradle打包
  5. 10、单机运行环境搭建之 --Windows下mysqldump 备份与还原数据库
  6. MapInfo导入.TAB和.mws的方法
  7. socketserver
  8. 常用PHP array数组函数
  9. Linux 查看进程和删除进程
  10. WebPack在多页应用项目中的探索