ALV小计项目设定

 REPORT  ZHANGTEST.
TYPE-POOLS: slis.

TYPES: BEGIN OF ty_data,
        key(10),
        n TYPE i,
        text TYPE c LENGTH 50,
        color_cell  TYPE slis_t_specialcol_alv,  " Cell color
     END OF ty_data.
DATA: gt_fieldcat TYPE slis_t_fieldcat_alv,
     gt_sort     TYPE slis_t_sortinfo_alv,
     gs_layout   TYPE slis_layout_alv.

DATA: gt_data TYPE TABLE OF ty_data WITH KEY key WITH HEADER LINE.

*---------------------------------------------------------------------*
INITIALIZATION.
  PERFORM e01_fieldcat_init  CHANGING gt_fieldcat[].
  PERFORM e02_layout_sort_build CHANGING gt_sort.
*---------------------------------------------------------------------*
START-OF-SELECTION.
  PERFORM selection.

*---------------------------------------------------------------------*
END-OF-SELECTION.
  gs_layout-zebra             = 'X'.
*  gs_layout-COLWIDTH_OPTIMIZE = 'X'.
  gs_layout-coltab_fieldname = 'COLOR_CELL'.
  gs_layout-subtotals_text    = '小計:'.

* CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      i_callback_program = sy-repid
      is_layout          = gs_layout
      it_fieldcat        = gt_fieldcat[]
      it_sort            = gt_sort[]

    TABLES
      t_outtab           = gt_data
    EXCEPTIONS
      program_error      = 1
      OTHERS             = 2.

*---------------------------------------------------------------------*
*  -->  E01_LT_FIELDCAT                                               *
*---------------------------------------------------------------------*
FORM e01_fieldcat_init CHANGING e01_lt_fieldcat TYPE slis_t_fieldcat_alv
.
  DATA: ls_fieldcat TYPE slis_fieldcat_alv.

* Key
  CLEAR ls_fieldcat.
  ls_fieldcat-fieldname    = 'KEY'.
  ls_fieldcat-tabname      = 'GT_DATA'.
  ls_fieldcat-reptext_ddic = 'KEY'.
  ls_fieldcat-outputlen    = 10.
  APPEND ls_fieldcat TO e01_lt_fieldcat.

* Test number
  CLEAR ls_fieldcat.
  ls_fieldcat-fieldname    = 'N'.
  ls_fieldcat-tabname      = 'GT_DATA'.
  ls_fieldcat-reptext_ddic = 'Num#'.
  ls_fieldcat-do_sum = 'X'.
  ls_fieldcat-outputlen    = 10.
  APPEND ls_fieldcat TO e01_lt_fieldcat.

* Text
  CLEAR ls_fieldcat.
  ls_fieldcat-fieldname    = 'TEXT'.
  ls_fieldcat-tabname      = 'GT_DATA'.
  ls_fieldcat-reptext_ddic = 'Text'.
  ls_fieldcat-outputlen    = 40.
  APPEND ls_fieldcat TO e01_lt_fieldcat.
ENDFORM.                    "e01_fieldcat_init
*&---------------------------------------------------------------------*

*&      Form  e02layout_sort_build
*&---------------------------------------------------------------------*

*       text
*----------------------------------------------------------------------*

*      -->LT_SORT    text
*----------------------------------------------------------------------*

FORM e02_layout_sort_build CHANGING lt_sort TYPE slis_t_sortinfo_alv.
  DATA ls_sort TYPE slis_sortinfo_alv.
* Key
  CLEAR ls_sort.
  ls_sort-fieldname = 'KEY'.
  ls_sort-spos      = 1.
  ls_sort-up        = 'X'.
  ls_sort-subtot    = 'X'.
  APPEND ls_sort TO lt_sort.

*  CLEAR ls_sort.
*  ls_sort-fieldname = 'N'.
*  ls_sort-spos      = 1.
*  ls_sort-up        = 'X'.
*  ls_sort-subtot    = 'X'.
*  APPEND ls_sort TO lt_sort.
ENDFORM.  " e02_LAYOUT_sort_build
*---------------------------------------------------------------------*
*       FORM SELECTION                                                *
*---------------------------------------------------------------------*
*                                                            *
*---------------------------------------------------------------------*
FORM selection.
  gt_data-key  = 'Group 1'.  gt_data-n = 19734. gt_data-text = 'Mat 1'.
  APPEND gt_data.
  gt_data-key  = 'Group 2'.  gt_data-n = 20001. gt_data-text = 'Mat 2'.
  APPEND gt_data.
  gt_data-key  = 'Group 1'.  gt_data-n = 22001. gt_data-text = 'Mat 3'.
  APPEND gt_data.
  gt_data-key  = 'Group 1'.  gt_data-n = 2200.  gt_data-text = 'Mat 4'.
  APPEND gt_data.
  gt_data-key  = 'Group 2'.  gt_data-n = 10001. gt_data-text = 'MAt 5'.
  APPEND gt_data.

*  FIELD-SYMBOLS <data> LIKE LINE OF gt_data.
*  DATA: ls_color TYPE slis_specialcol_alv,
*        red_color TYPE slis_t_specialcol_alv,
*        green_color TYPE slis_t_specialcol_alv.
*
*  ls_color-fieldname = 'N'. ls_color-color-int = '0'.
*  ls_color-color-inv = '1'.
*  ls_color-color-col = '6'. APPEND ls_color TO red_color.
*  ls_color-color-col = '5'. APPEND ls_color TO green_color.

ENDFORM.                    "selection

### ABAP ALV 双击行事件处理 示例代码 在ABAP中实现ALV网格双击行的功能,可以通过`REUSE_ALV_GRID_DISPLAY`函数模块来完成。此过程涉及设置事件处理器以及绑定自定义方法以响应用户的双击行为。 以下是完整的示例代码: ```abap REPORT zdemo_alv_double_click. TABLES: vbap. TYPE-POOLS: slis. DATA: gt_fieldcat TYPE slis_t_fieldcat_alv, gs_layout TYPE slis_layout_alv, go_custom_container TYPE REF TO cl_gui_custom_container, go_grid TYPE REF TO cl_gui_alv_grid, it_vbap TYPE TABLE OF vbap. START-OF-SELECTION. SELECT * FROM vbap INTO TABLE it_vbap UP TO 10 ROWS. CALL FUNCTION 'REUSE_ALV_FIELDNAME_GET' EXPORTING i_program_name = sy-repid IMPORTING et_fielddescription = gt_fieldcat[]. * 设置布局参数并启用双击事件 gs_layout-edit = 'X'. gs_layout-coltab_fname = 'VBELN'. * 创建自定义容器和ALV Grid对象 CREATE OBJECT go_custom_container EXPORTING container_name = 'CUSTOM_CONTAINER'. CREATE OBJECT go_grid EXPORTING i_parent = go_custom_container. * 显示ALV Grid CALL METHOD go_grid->set_table_for_first_display EXPORTING is_layout = gs_layout CHANGING it_outtab = it_vbap it_fieldcatalog = gt_fieldcat. * 注册双击事件 SET HANDLER on_double_click FOR go_grid. END-OF-SELECTION. METHOD on_double_click. DATA: lv_row_no TYPE i, ls_key TYPE slis_selfield. FIELD-SYMBOLS: <wa> TYPE any. * 获取当前选中的行号 CALL METHOD sender->get_current_cell_info IMPORTING e_row = lv_row_no. * 判断是否有有效行被点击 IF lv_row_no IS INITIAL. RETURN. ENDIF. * 获取对应的数据记录 READ TABLE it_vbap ASSIGNING <wa> INDEX lv_row_no. * 执行业务逻辑(例如弹出消息框) MESSAGE |You double-clicked row { lv_row_no } with VBELN: { <wa>-vbeln }| TYPE 'I'. ENDMETHOD. ``` #### 解析 上述代码实现了以下功能: 1. 使用`REUSE_ALV_GRID_DISPLAY`函数模块加载数据至ALV表格[^4]。 2. 配置了ALV的布局属性,并启用了编辑模式以便支持交互操作。 3. 定义了一个名为`on_double_click`的方法作为双击事件的处理器[^1]。 4. 当用户双击某一行时,程序会获取该行的信息并通过消息提示展示给用户[^2]。 注意,在实际应用开发过程中可能还需要进一步完善错误处理机制及用户体验优化等内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值