*激发双击事件
FORM f_alv_user_command USING r_ucomm LIKE sy-ucomm
rs_selfield TYPE slis_selfield. "先引用类型池 TYPE-POOLS: slis CASE r_ucomm.
WHEN '&IC1'.
PERFORM double_click USING rs_selfield-tabindex "双击显示明细
rs_selfield-fieldname .
ENDCASE. FORM double_click USING p_tabindex "双击行号
p_fieldname. "双击列名
DATA:l_bewtp TYPE ekbe-bewtp. READ TABLE gt_output INTO wa_output INDEX p_tabindex.
CHECK sy-subrc = . REFRESH:gt_ekbe_alv.
IF p_fieldname = 'TOTAL'.
l_bewtp = 'E'.
ELSEIF p_fieldname = 'FP_TOTAL'.
l_bewtp = 'Q'.
ELSEIF p_fieldname = 'EBELN'.
SET PARAMETER ID 'BES' FIELD wa_output-ebeln. "调用ME23N界面,详细可见CALL TRANSACTION小节一文
SET PARAMETER ID 'BSP' FIELD wa_output-ebelp.
CALL TRANSACTION 'ME23N' AND SKIP FIRST SCREEN.
ELSE.
EXIT.
ENDIF. LOOP AT gt_ekbe INTO wa_ekbe WHERE ebeln = wa_output-ebeln
AND ebelp = wa_output-ebelp
AND bewtp = l_bewtp.
APPEND wa_ekbe TO gt_ekbe_alv.
ENDLOOP.
IF gt_ekbe_alv IS INITIAL..
MESSAGE s398() WITH '无数据' .
EXIT.
ENDIF.
g_fieldname = p_fieldname. CALL SCREEN .
ENDFORM. *自定义工具栏,如果没有自定义的按钮不需要设置,系统会有标准的工具栏,如果设置了自定义工具栏,会替代标准工具栏,
*系统标准ALV工具栏可以通过函数的REUSE_ALV_GRID_DISPLAY_LVC找到函数组SLVC_FULLSCREEN,在函数组下面的GUI状态名:
*SAPLSLVC_FULLSCREEN就是标准的ALV工具栏,可以以拷贝使用。
FORM f_set_alv_status_00 USING i_extab TYPE slis_t_extab.
SET PF-STATUS 'GUISTATUS_00'.
ENDFORM. CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
EXPORTING
i_callback_program = sy-repid
i_callback_pf_status_set = 'F_SET_ALV_STATUS_00'
i_callback_user_command = 'F_ALV_USER_COMMAND'
is_layout_lvc = gs_layout
it_fieldcat_lvc = gt_field
i_save = 'A'
TABLES
t_outtab = gt_output
EXCEPTIONS
program_error =
OTHERS = .
IF sy-subrc <> .
MESSAGE ID sy-msgid
TYPE 'S'
NUMBER sy-msgno
WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4
DISPLAY LIKE 'E'. LEAVE LIST-PROCESSING. "ALV执行失败退回到选择界面 ENDIF.

.以上是函数模式的ALV和热点,下面介绍OO方式的

*---------------------------------------------------------------------*
* CLASS 参数定义
*---------------------------------------------------------------------*
CLASS lcl_alv_receiver DEFINITION DEFERRED. "预定义本地类
DATA: g_alv_application TYPE REF TO lcl_alv_receiver. "按钮处理 *----------------------------------------------------------------------*
* CLASS lcl_alv_receiver DEFINITION
*----------------------------------------------------------------------*
*
*----------------------------------------------------------------------*
CLASS lcl_alv_receiver DEFINITION. "定义本地类
PUBLIC SECTION.
METHODS:
handle_double "执行双击事件
FOR EVENT double_click OF cl_gui_alv_grid
IMPORTING e_row e_column es_row_no.
ENDCLASS. "lcl_event_receiver DEFINITION
*----------------------------------------------------------------------*
* CLASS lcl_alv_receiver IMPLEMENTATION
*----------------------------------------------------------------------*
*
*----------------------------------------------------------------------*
CLASS lcl_alv_receiver IMPLEMENTATION.
METHOD handle_double . "双击事方法件的实现
PERFORM set_double_click_class USING e_row e_column.
ENDMETHOD. "HANDLE_double
ENDCLASS. "lcl_event_receiver IMPLEMENTATION FORM set_double_click_class USING p_row TYPE lvc_s_row
p_column TYPE lvc_s_col.
CHECK g_fieldname = 'TOTAL'.
READ TABLE gt_ekbe_alv INTO wa_ekbe INDEX p_row-index.
CHECK sy-subrc = . IF p_column-fieldname = 'BELNR'.
SET PARAMETER ID 'MBN' FIELD wa_ekbe-belnr.
SET PARAMETER ID 'MJA' FIELD wa_ekbe-gjahr.
CALL TRANSACTION 'MB03' AND SKIP FIRST SCREEN.
ELSEIF p_column-fieldname = 'EBELN'.
SET PARAMETER ID 'BES' FIELD wa_ekbe-ebeln.
SET PARAMETER ID 'BSP' FIELD wa_ekbe-ebelp.
CALL TRANSACTION 'ME23N' AND SKIP FIRST SCREEN.
ENDIF.
ENDFORM. DATA: g_grid TYPE REF TO cl_gui_alv_grid. "ALV类
DATA:g_custom_container TYPE REF TO cl_gui_custom_container,
g_container TYPE scrfname VALUE 'CONTAINER', "界面绘制的ALV容器名称 'CONTAINER'
gt_exclude TYPE ui_functions. "存放ALV排除工具栏功能按钮的内表 CREATE OBJECT g_custom_container
EXPORTING
container_name = g_container. "界面绘制的ALV容器名称 'CONTAINER'
CREATE OBJECT g_grid
EXPORTING
i_parent = g_custom_container. 初始化ALV类 ***去除不需要的按钮
PERFORM exclude_tb_functions CHANGING gt_exclude. ***显示ALV
PERFORM screen_alv.
CREATE OBJECT g_alv_application.
SET HANDLER g_alv_application->handle_double FOR g_grid. FORM exclude_tb_functions CHANGING pt_exclude TYPE ui_functions.
DATA ls_exclude TYPE ui_func.
ls_exclude = cl_gui_alv_grid=>mc_fc_loc_copy_row.
APPEND ls_exclude TO pt_exclude.
ls_exclude = cl_gui_alv_grid=>mc_fc_loc_delete_row.
APPEND ls_exclude TO pt_exclude.
ls_exclude = cl_gui_alv_grid=>mc_fc_loc_append_row.
APPEND ls_exclude TO pt_exclude.
ls_exclude = cl_gui_alv_grid=>mc_fc_loc_insert_row.
APPEND ls_exclude TO pt_exclude.
ls_exclude = cl_gui_alv_grid=>mc_fc_loc_move_row.
APPEND ls_exclude TO pt_exclude.
ENDFORM. FORM screen_alv .
gs_variant-report = sy-repid.
CALL METHOD g_grid->set_table_for_first_display
EXPORTING
it_toolbar_excluding = gt_exclude
is_layout = gs_layout
is_variant = gs_variant
i_save = 'A'
CHANGING
it_fieldcatalog = gt_fieldcat
it_outtab = gt_ekbe_alv.
ENDFORM.

ALV双击单元格事件处理的更多相关文章

  1. ABAP ALV单个单元格状态编辑

    *&---------------------------------------------------------------------* *& Report  ZPPR0024 ...

  2. ABAP ALV单个单元格状态编辑-简单版本

    *&---------------------------------------------------------------------* *& Report  ZPPR0024 ...

  3. ABAP分享五 ALV修改单元格并将修改数据更新到数据表中示例1

    *下面的代码是在alv字段中修改字段的内容,点击保存后就可以保存数据至数据表. TABLES: spfli. DATA: wa_fieldcat TYPE lvc_s_fcat ,  " 相 ...

  4. vue elementui table 双击单元格实现编辑,聚焦,失去焦点,显示隐藏input和span

    <el-table :data="tableData" class="tb-edit" style="width: 100%" ref ...

  5. Excel双击“单元格”后,自动跳转到相关“工作表

    Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)If Target.Column = ...

  6. Delphi DBGrid双击事件、单元格操作

    1.得到当前格子中的内容:DBGrid1.Fields[DBGrid1.SelectedIndex].DisplayText;把DBGrid1.SelectedIndex改为你所希望引用的字段就可以了 ...

  7. Swing-JTable检测单元格数据变更事件

    在JTable的初级教程中往往会提到,使用TableModel的 addTableModelListener方法可以监听单元格数据的变更,在其事件处理函,数tableChanged中,可以通过e.ge ...

  8. ASP.NET 导出gridview中的数据到Excel表中,并对指定单元格换行操作

    1. 使用NPOI读取及生成excel表. (1)导出Click事件: 获取DataTable; 给文件加文件名: string xlsxName = "xxx_" + DateT ...

  9. QTableWidget 用法总结(只能使用标准的数据模型,并且其单元格数据是QTableWidgetItem的对象)

    QTableWidget是QT程序中常用的显示数据表格的空间,很类似于VC.C#中的DataGrid.说到QTableWidget,就必须讲一下它跟QTabelView的区别了.QTableWidge ...

随机推荐

  1. FLUSH TABLES WITH READ LOCK 锁全局

    [root@wx03 ~]# cat a3.sh mysql -uroot -p1234567<<eof use scan; FLUSH TABLES WITH READ LOCK; sy ...

  2. Ubuntu: 搭建tftp,nfs服务器

    Ubuntu12.04搭建tftp&nfs服务器 http://blog.163.com/thinki_cao/blog/static/83944875201411610467306/ 硬件环 ...

  3. PostgreSQL正则表达式查询

    参考http://www.php100.com/manual/PostgreSQL8/functions-matching.html LIKE string LIKE pattern [ ESCAPE ...

  4. getopt、getopt_long和getopt_long_only

    GNU/Linux的命令行选项有两种类型:短选项和长选项,前者以 '-' 作为前导符,后者以 '--' 作为前导符.比如有一个命令: $ myprog -a vv --add -b --file a. ...

  5. 在mac os 中安装 autoconf and automake

    转载地址:http://www.mattvsworld.com/blog/2010/02/install-the-latest-autoconf-and-automake-on-mac-os-10-6 ...

  6. android 小结

    1.layout中的布局文件xml中不能有大写字母. 2.时刻要想着空指针,尤其是安卓5.0后,不报异常,直接ANR.

  7. Jquery学习笔记:利用find和children方法获取后代元素

    在很多场景下,需要根据一个已知的jquery对象,去查找其满足条件的后代节点. 这时可以利用 find函数和children来处理. find和children函数都可有一个参数,常见的是一个字符串, ...

  8. MUI跳转页面传值

    1.打开新的页面.通过 mui.openWindow 打开页面extras参数传递参数 mui.openWindow({ id: "yingshou-" + newid, url: ...

  9. MSSQL - 尚未备份数据库 xxxx 的日志尾部。如果该日志包含您不希望丢失的工作,请使用 BACKUP LOG WITH NORECOVERY 备份该日志。请使用 RESTORE 语句的 WITH REPLA

    此错误的原因是:你的数据库服务器中存在同名数据库! RESTORE DATABASE  [student] FROM  DISK = N'G:\备份文件'  WITH  FILE = 1, MOVE ...

  10. MIPI CSI-2规范一——概述及层级

    MIPI CSI-2规范一——概述及层级 CSI-2概述 CSI-2规范定义了发送者和接收者之间传输和控制接口的标准数据.数据传输接口(指CSI-2)是单向差分串行接口,传输数据和始终信号:接口的物理 ...