一起学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

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

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

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