ALV有两种写法,一种是FUCTION(FM),另一种就是OOALV
代码语言:javascript复制DATA BEGIN OF gs_data,
sel,
gjahr TYPE acdoca-gjahr, "年度
poper TYPE acdoca-poper, "期间
belnr TYPE acdoca-belnr, "凭证编码
docln TYPE acdoca-docln, "行项目
prctr TYPE acdoca-prctr, "利润中心
prctr_mc TYPE cepct-ktext, "利润中心名称
racct TYPE acdoca-racct, "科目
kunnr TYPE acdoca-kunnr, "客户
kunnr_mc TYPE kna1-name1, "客户名称
lifnr TYPE acdoca-lifnr, "供应商
lifnr_mc TYPE lfa1-name1, "供应商名称
zzyg TYPE acdoca-zzyg, "POS流水号
zzks TYPE acdoca-zzks, "外围系统单据号
hsl TYPE acdoca-hsl, "金额
color TYPE char4, "设置行的颜色
END OF gs_data.
DATA gt_data LIKE TABLE OF gs_data.
1、FUCTION ALV复选列形式
- gs_lout-box_fname = 'SEL'. "设置选择列
* 复选框
* CLEAR gs_fcat .
* gs_fcat-fieldname = 'SEL' .
* gs_fcat-scrtext_l = '复选框' .
* gs_fcat-checkbox = 'X'.
* gs_fcat-edit = 'X'.
* gs_fcat-key = 'X'.
** ls_fcat2-hotspot = 'X'.
* APPEND gs_fcat TO gt_fcat.
2、 OOALV ALV复选列形式
- gs_lout-sel_mode = 'D'.
注:通过结构 LVC_S_LAYO-SEL_MODE 字段对应的值有: 1、sapce,等同于B,默认的设置。 2、A(行与列的选择,无法选择单元格)。 3、B(单选,不可以多选行,不可以多选单元格)。 4、C(多选行、列,不可以多选单元格)。 5、D(多选行、列,还可以多选单元格)。
通过CL_GUI_ALV_GRID-> GET_SELECTED_ROWS的方法来获取选中列对应的在输出内表中的行ID
代码语言:javascript复制DATA : LT_ROW TYPE LVC_T_ROID, "内表
LS_ROW TYPE LVC_S_ROID. "工作区
" ALV里选择一行时,给这行某字段打X且修改ALV
CALL METHOD go_grid->get_selected_rows
importing
et_row_no = lt_row.
LOOP AT lt_row INTO ls_row.
READ TABLE gt_alv INTO gs_alv index ls_row-row_id .
IF sy-subrc EQ 0 .
gs_alv-sel = 'X'.
MODIFY gt_alv FROM gs_alv INDEX SY-TABIX TRANSPORTING sel.
CLEAR : gs_alv.
ENDIF .
ENDLOOP .