ALV双击单元格事件处理
*激发双击事件
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双击单元格事件处理的更多相关文章
- ABAP ALV单个单元格状态编辑
*&---------------------------------------------------------------------* *& Report ZPPR0024 ...
- ABAP ALV单个单元格状态编辑-简单版本
*&---------------------------------------------------------------------* *& Report ZPPR0024 ...
- ABAP分享五 ALV修改单元格并将修改数据更新到数据表中示例1
*下面的代码是在alv字段中修改字段的内容,点击保存后就可以保存数据至数据表. TABLES: spfli. DATA: wa_fieldcat TYPE lvc_s_fcat , " 相 ...
- vue elementui table 双击单元格实现编辑,聚焦,失去焦点,显示隐藏input和span
<el-table :data="tableData" class="tb-edit" style="width: 100%" ref ...
- Excel双击“单元格”后,自动跳转到相关“工作表
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)If Target.Column = ...
- Delphi DBGrid双击事件、单元格操作
1.得到当前格子中的内容:DBGrid1.Fields[DBGrid1.SelectedIndex].DisplayText;把DBGrid1.SelectedIndex改为你所希望引用的字段就可以了 ...
- Swing-JTable检测单元格数据变更事件
在JTable的初级教程中往往会提到,使用TableModel的 addTableModelListener方法可以监听单元格数据的变更,在其事件处理函,数tableChanged中,可以通过e.ge ...
- ASP.NET 导出gridview中的数据到Excel表中,并对指定单元格换行操作
1. 使用NPOI读取及生成excel表. (1)导出Click事件: 获取DataTable; 给文件加文件名: string xlsxName = "xxx_" + DateT ...
- QTableWidget 用法总结(只能使用标准的数据模型,并且其单元格数据是QTableWidgetItem的对象)
QTableWidget是QT程序中常用的显示数据表格的空间,很类似于VC.C#中的DataGrid.说到QTableWidget,就必须讲一下它跟QTabelView的区别了.QTableWidge ...
随机推荐
- 引用 U-boot给kernel传参数和kernel读取参数—struct tag
引用 清风徐徐 的 U-boot给kernel传参数和kernel读取参数—struct tag U-boot会给Linux Kernel传递很多参数,如:串口,RAM,videofb等.而Linux ...
- JAVAC 命令使用方法
结构 javac [ options ] [ sourcefiles ] [ @files ] 參数可按随意次序排列. options 命令行选项. sourcefiles 一个或多个要编译的源文件( ...
- Failed to retrieve procctx from ht. constr
给一个客户巡检时发生这样的少见的集群报错: [ OCRSRV][1220598112]th_select_handler: Failed to retrieve procctx from ht. c ...
- CocoaPods on Xcode 6 and Yosemite
老子今天又给环境跪了..... cocoapods 在升级完新系统以后无法工作 解决cocoapods 在 mac 10.10下报错 错误例如以下. /System/Library/Framework ...
- 零成本建立的.NET小组开发平台
前言 说道.NET开发平台,首先想到的就是Visual Studio,建立.NET小组开发平台自然首推TFS.但其花费却也是相当昂贵的(当然在本国可以无视这些成本),近期的开发中接触到一些开源软件并读 ...
- ZOJ 3607贪心算法
http://blog.csdn.net/ffq5050139/article/details/7832991 http://blog.watashi.ws/1944/the-8th-zjpcpc/ ...
- 高性能MySql学习笔记——锁、事务、隔离级别(转)
为什么需要锁? 因为数据库要解决并发控制问题.在同一时刻,可能会有多个客户端对Table1.rown进行操作,比如有的在读取该行数据,其他的尝试去删除它.为了保证数据的一致性,数据库就要对这种并发操作 ...
- 浅谈MySql的存储引擎(表类型) (转)
什么是MySql数据库 通常意义上,数据库也就是数据的集合,具体到计算机上数据库可以是存储器上一些文件的集合或者一些内存数据的集合. 我们通常说的MySql数据库,sql server数据库等等其实是 ...
- opencv实现连通域
在本文中使用图像连通域统计使用opencv中的cvFloodFill方法,可是在cvFloodFill方法中CvConnectedComp參数无法返回详细点坐标位置信息,找了些资料.给CvSeq分配空 ...
- 它们的定义View
Ios"巷自己的定义View和Android类别似 在.h文件设置了他的一些财产.方法 在.m文件中实现 .h文件 #import <UIKit/UIKit.h> CGPoint ...