一起学FPM之 UIBB间的数据传递

2024-03-05 08:08
文章标签 数据 fpm 传递 一起 uibb

本文主要是介绍一起学FPM之 UIBB间的数据传递,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

初认识

Dylan,公众号:ABAP 技巧与实战一起学FPM之 初识SAP_FPM

文末附加了源代码. 附加源代码是以 查询T001W为查询目标, 如果与你测试的表不同, 请调整相关内容. 

读过上一篇并且自己做了demo的朋友们肯定有一些疑问,到底如何根据搜索条件关联到查询结果表?本文就来详细说明一下这个疑问,关于UIBB间数据的传递。

首先我们来看一下看完这篇文档能做出的效果:

前端页面直接进行查询:

按搜索条件查询:

FPM中不同UIBB的值如何传递呢?基本可以给出两种方式:

一是通过标准的传递方式,FPM提供了SET_VALUE和GET_VALUE的方法。

二是使用全局类的方式交互。

SEARCH的类中,找到PROCESS_EVENT方法,打上断点,在前台输入如下条件执行:

可以看到SEARCH类的IF_FPM_SEARCH_CRITERIA已经可以拿到在页面输入的参数了

接下来我们看是如何实现的:

  1. 在SEARCH类的PROCESS_EVENT方法中,使用框架提供的方法SET_VALUE( ),添加如下代码:

     SET_VALUE( ):

     2.来到LIST类的GET_DATA方法中,使用框架提供的方法GET_VALUE(               ),添加如下代码:

大家可以通过上面的代码看到GET_VALUE后是如何转为可以使用的range类型的,再之后就比较好理解了,就是取数,

注意需要添加ev_data_changed = 'X' 的语句实现数据刷新,原理和ALV相同。

以上完成后,到前端页面输入条件,执行后就可以达成文初展示的效果了。

需要注意的是: SET_VALUE和GET_VALUE方法的传值思路,在SEARCH的process_event中通过SET_VALUE把查询条件抛到LIST中做查询,同样也可以在SEARCH中直接获取range,写好逻辑,查询结果后把结果内表抛到LIST中,LIST仅将查询结果做展示;当然也可以不用这个方法,自己去封装一个全局类去规划全局参数传递等等,这些都需要大家根据自己的开发思路和项目具体的情况进行思考。

附加的源代码部分一:  ZFPM_DEMO_SEARCH  

IF_FPM_GUIBB_SEARCH~PROCESS_EVENT

  METHOD if_fpm_guibb_search~process_event.BREAK cabap01.DATA: lo_fpm TYPE REF TO if_fpm.DATA(lo_fpm_para) = NEW cl_fpm_parameter( ).
*判断事件IDIF io_event->mv_event_id = if_fpm_guibb_search=>fpm_execute_search.lo_fpm = cl_fpm_factory=>get_instance( ).lo_fpm_para->if_fpm_parameter~set_value(iv_key = 'SEL_TAB'iv_value = it_fpm_search_criteria ).lo_fpm->raise_event_by_id(iv_event_id = if_fpm_guibb_list=>gc_event_list_filterio_event_data = lo_fpm_para ).ENDIF.ENDMETHOD.

附加的源代码部分二: ZFPM_DEMO_LIST

IF_FPM_GUIBB_LIST~GET_DATA

  METHOD if_fpm_guibb_list~get_data.BREAK cabap01.DATA: lr_werks    TYPE peg_t_werks.DATA: lt_search TYPE fpmgb_t_search_criteria,lo_rtti   TYPE REF TO cl_abap_datadescr,lo_exc    TYPE REF TO cx_fpmgb,ls_selopt TYPE rsdsselopt,ls_range  TYPE rsds_frange,lt_ranges TYPE TABLE OF rsds_frange.CASE iv_eventid->mv_event_id.WHEN if_fpm_guibb_list=>gc_event_list_filter."SEARCH 中抛出的选择条件, 这里接收iv_eventid->mo_event_data->get_value(EXPORTINGiv_key = 'SEL_TAB'IMPORTINGev_value = lt_search )."转换查询条件为RANGE"CLEAR lr_werks.LOOP AT lt_search REFERENCE INTO DATA(lr_search).TRY .ls_selopt = cl_fpm_guibb_search_conversion=>to_abap_select_option(is_fpm_search_row = lr_search->*  io_attr_rtti = lo_rtti ).CATCH cx_fpmgb INTO lo_exc.ENDTRY.APPEND ls_selopt TO ls_range-selopt_t.ls_range-fieldname = lr_search->search_attribute.APPEND ls_range TO lt_ranges.CLEAR ls_range.APPEND VALUE #( sign = ls_selopt-sign option = ls_selopt-optionlow = ls_selopt-low high = ls_selopt-high ) TO lr_werks.ENDLOOP.SELECT * FROM t001w INTO TABLE @DATA(lt_t001w)WHERE werks IN @lr_werks.ct_data = lt_t001w.ev_data_changed = abap_true.WHEN OTHERS.ENDCASE.
*          lr_werks = zfpm_demo_trans_data=>gr_werks .ENDMETHOD.

这篇关于一起学FPM之 UIBB间的数据传递的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/775833

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名