这个就是通过对应的选择列,实现对ALV数据的选择,在调用函数的ALV和面向对象的ALV
实现方法存在差异,下面讲两者的方法:
1)调用函数的ALV。
通过 SLIS_LAYOUT_ALV-BOX_FIELDNAME的字段来设置,这个字段的值对应的是输出内表的
一个字段名字(专门用于标记选择哪些列,选中的为‘X’),其实这种实现方法就跟平时我
们增加一列复选择框用于选择的方法大致一样的,但是这种方法选择的方式比较快。
2)面向对象的ALV。
通过结构 LVC_S_LAYO-SEL_MODE的了段来设置,这个字段对应的值有以下5个:
1、sapce,等同于B,默认的设置。
2、A(行与列的选择,无法选择单元格)。
3、B(单选,不可以多选行,不可以多选单元格)。
4、C(多选行、列,不可以多选单元格)。
5、D(多选行、列,还可以多选单元格)。
只有设置的值为‘C’或者‘D’带选择列才可以显示出来,其它值一概不行。如果ALV输出
有列是可以编辑,则会覆盖了 sel_mode的值,带选择列也会显示出来的哦。
通过与1)种方法比较,很容易发现2)种方法没有通过内表的一个字段值来记录哪些值没选
中了,那我们如何知道哪些列被选中了呢?可以通过CL_GUI_ALV_GRID-> GET_SELECTED_ROWS的
方法来获取选中列对应的在输出内表中的行ID了,具体就看下面的例子了:
DATA: lt_sel_rows TYPE lvc_t_roid,
ls_sel_rows TYPE lvc_s_roid.
DATA: ls_stbl TYPE lvc_s_stbl."ALV 控制:刷新稳定性
CLEAR:lt_sel_rows,ls_sel_rows.
DATA:lv_flag TYPE char1.
CLEAR:lv_flag.
g_ok_code = sy-ucomm.
CALL METHOD g_grid_alv->get_selected_rows
IMPORTING
et_row_no = lt_sel_rows.
LOOP AT lt_sel_rows INTO ls_sel_rows.
READ TABLE gt_item INTO gw_item INDEX ls_sel_rows-row_id.
IF gw_item-icon = ‘@5B@’.
MESSAGE ‘审批状态已经变更,无法再次审批’ TYPE ‘E’.
ENDIF.
CLEAR:ls_sel_rows.
ENDLOOP.