SAP增强 BADI屏幕增强实例(MIGO增加分页签)

最终效果:以下根据系统实例做的

(需要注意第4步中的UPDATE函数配置)

 

1、SE11建立数据表,主要是用于存放附加的数据;

MANDT     MANDT   CLNT        3       0       客户端

MBLNR     MBLNR    CHAR       10    0       物料凭证编号

MJAHR      MJAHR     NUMC     4       0       物料凭证年度

ZEILE       MBLPO    NUMC     4       0       物料凭证中的项目

BADI_ERFMG   ERFMG    QUAN      13    3       以输入单位计的数量

BADI_ERFME    ERFME     UNIT        3       0       条目单位

2、建立结构,在屏幕数据交换时使用

3、建立表类型

设置关键字段:

4、SE80建立函数组

注意:ZJIM_BADI_EXAMPLE_UPDATE_DATA

创建屏幕1000,

设计格式,插入附加字段

创建function: ZJIM_BADI_EXAMPLE_GET_DATA

*"----------------------------------------------------------------------
*"*"Local interface:
*"  EXPORTING
*"     REFERENCE(ES_MIGO_BADI_SCREEN_FIELDS) TYPE
*"        ZJIM_BADI_EXAMPLE_SCREEN_FIELD
*"----------------------------------------------------------------------

* Get all data from fields of external screen
* First move all customer-fields
  MOVE-CORRESPONDING zjim_badi_exampl TO es_migo_badi_screen_fields.
* Second move all GOITEM-fields (displayed on external screen)

 

 

function: ZJIM_BADI_EXAMPLE_PUT_DATA

*"----------------------------------------------------------------------
*"*"Local interface:
*"  IMPORTING
*"     REFERENCE(IS_MIGO_BADI_SCREEN_FIELDS) TYPE
*"        ZJIM_BADI_EXAMPLE_SCREEN_FIELD
*"----------------------------------------------------------------------

* Put all data from fields to external screen
* First fill all customer-fields
  MOVE-CORRESPONDING is_migo_badi_screen_fields TO ZJIM_badi_exampl.
* second fill all GOITEM-fields (displayed on external screen)

 

 

 

function: ZJIM_BADI_EXAMPLE_UPDATE_DATA

*"----------------------------------------------------------------------
*"*"Update function module:
*"
*"*"Local interface:
*"  TABLES
*"      IT_MIGO_BADI_EXAMPLE STRUCTURE  ZJIM_BADI_EXAMPL
*"----------------------------------------------------------------------

* Databse update:
  INSERT zjim_BADI_EXAMPL FROM TABLE IT_MIGO_BADI_EXAMPLE.
  IF sy-subrc <> 0.
    MESSAGE a398(00WITH 'Error update MIGO_BADI_EXAMPL'.
  ENDIF.

INCLUDE : LZJIM_BADI001TOP

TABLES Zjim_badi_exampl.

到这里增强的准备工作就做完了,下面开始创建实现:

5、SE19创建实现

 

6、创建执行类ZCL_IM_JIM_MIGO_BADI,激活ZJIM_MIGO_BADI  

 SE80  class

SE37 查看函数

以上界面:SE19

双击类

维护类属性

GT_EXTDATA 用于数据交换,类型为ZJIM_TY_T_EXTDATA表类型,

7、激活以下方法并维护:

method IF_EX_MB_MIGO_BADI~INIT.
* Regristration of BAdI-Implementation:
* Append class attribute GF_CLASS_ID (='MIGO_BADI_IMPLEMENTATION1') to
* regristration table.
  APPEND gf_class_id TO ct_init.
endmethod.

 

METHOD IF_EX_MB_MIGO_BADI~PBO_DETAIL .
  DATAls_extdata TYPE zjim_badi_example_screen_field.
* This check is obligatory, otherwise the program flow is incorrect
* (If there would be more than one implementation of BAdI MB_MIGO_BADI,
*  only one subscreen would be displayed).
  CHECK i_class_id gf_class_id.
* Show screen only if there is an item
  CHECK i_line_id <> 0.
* External subscreen:
* The content of global field G_NO_INPUT (set in method MODE_SET) will
* influence the number of external subsreen:
  if g_no_input is initial.
    e_cprog   'SAPLZJIM_BADI001'(006).  "程序名为定义的函数组的名称前加“SAPL“。
    e_dynnr   '1000'.                     "External fields: Input
    e_heading 'ZJIM'(004). "显示标签的名称
  endif.
* Set G_LINE_ID (= line_id of item displayed on detail-tabstrip)
  g_line_id i_line_id.
* Read data
  READ TABLE gt_extdata INTO ls_extdata
     
WITH TABLE KEY line_id i_line_id.
* Export data to function group (for display on subscreen)
  CALL FUNCTION 'ZJIM_BADI_EXAMPLE_PUT_DATA'
    EXPORTING
      is_migo_badi_screen_fields ls_extdata.

ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~PBO_DETAIL

 

 

METHOD IF_EX_MB_MIGO_BADI~PAI_DETAIL .
*-----------------------------------------------------------------------
* Changing parameter E_FORCE_CHANGE can be set to 'X'. In this case
* method LINE_MODIFY is called.
* ATTENTION:
* DO NOT SET parameter E_FORCE_CHANGE = ' '. In this case you might
* overwrite parameter E_FORCE_CHANGE of another BAdI implementation.
*-----------------------------------------------------------------------
  DATAls_extdata_new TYPE zjim_badi_example_screen_field,
        ls_extdata_old TYPE zjim_badi_example_screen_field.

* Only if a line exists
  CHECK i_line_id <> 0.
* Get data from external screen
  CALL FUNCTION 'ZJIM_BADI_EXAMPLE_GET_DATA'
    IMPORTING
      es_migo_badi_screen_fields ls_extdata_new.
* Compare new data with old data
  READ TABLE gt_extdata INTO ls_extdata_old
     
WITH TABLE KEY line_id i_line_id.
  ls_extdata_new-line_id i_line_id.
  IF ls_extdata_old <> ls_extdata_new.
*   If there were any changes, it's obligatory to force MIGO to trigger
*   method LINE_MODIFY.
    e_force_change 'X'.
  ENDIF.

ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~PAI_DETAIL

 

METHOD IF_EX_MB_MIGO_BADI~LINE_MODIFY .
  DATAls_extdata_old      TYPE zjim_badi_example_screen_field,
        ls_extdata_new      TYPE zjim_badi_example_screen_field,
        ls_migo_badi_exampl TYPE zjim_badi_exampl,
        l_subrc             TYPE sy-subrc.

* Get external data from internal table:
  READ TABLE gt_extdata INTO ls_extdata_old
    
WITH TABLE KEY line_id i_line_id.
  l_subrc sy-subrc.

* Update data in internal table:
  IF l_subrc <> 0.
*   Line is new: If GOITEM has a reference to a material document,
*                the already existing external data can be read.
   IF NOT cs_goitem-mblnr IS INITIAL AND NOT cs_goitem-mjahr IS INITIAL
      AND NOT cs_goitem-zeile IS INITIAL.
      SELECT SINGLE FROM zjim_badi_exampl INTO ls_migo_badi_exampl
             
WHERE mblnr cs_goitem-mblnr
               
AND mjahr cs_goitem-mjahr
               
AND zeile cs_goitem-zeile.
      IF sy-subrc 0.
        MOVE-CORRESPONDING ls_migo_badi_exampl TO ls_extdata_new.
      ENDIF.
    ENDIF.
*    ls_extdata_new-sgtxt  = cs_goitem-sgtxt.
    ls_extdata_new-line_id i_line_id.
    INSERT ls_extdata_new INTO TABLE gt_extdata.
  ELSE.
*   Line exists: Get external data entered on BAdI-subscreeen, but only
*                if line_modify was called for the item displayed in the
*                'detail tabstrip'.
    check g_line_id i_line_id.
    CALL FUNCTION 'ZJIM_BADI_EXAMPLE_GET_DATA'
      IMPORTING
        es_migo_badi_screen_fields ls_extdata_new.
    ls_extdata_new-line_id i_line_id.
*    if ls_extdata_new-sgtxt <> ls_extdata_old-sgtxt.
**     Field was changed on external screen
*      cs_goitem-sgtxt = ls_extdata_new-sgtxt.
*    else.
**     Take data from GOITEM
*      ls_extdata_new-sgtxt = cs_goitem-sgtxt.
*    endif.
    MODIFY TABLE gt_extdata FROM ls_extdata_new.
  ENDIF.

ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~LINE_MODIFY

 

METHOD IF_EX_MB_MIGO_BADI~LINE_DELETE .
  DELETE TABLE gt_extdata WITH TABLE KEY line_id i_line_id.
ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~LINE_DELETE

 

METHOD IF_EX_MB_MIGO_BADI~POST_DOCUMENT .
  DATAls_migo_badi_example TYPE ZJIM_badi_exampl,
        lt_migo_badi_example TYPE TABLE OF zjim_badi_exampl,
        ls_extdata TYPE zjim_badi_example_screen_field,
        ls_xmseg   TYPE mseg.
  FIELD-SYMBOLS<gt_extdata> TYPE migo_badi_example_screen_field.
* Transaction MIGO will now post a material document.
* Any errors here MUST be issued as A-message (better: X-message)

* Copy data from material document into internal table
  LOOP AT gt_extdata INTO ls_extdata.
    IF g_cancel IS INITIAL.
      READ TABLE it_mseg INTO ls_xmseg
         
WITH KEY line_id ls_extdata-line_id.
    ELSE.
      READ TABLE it_mseg INTO ls_xmseg
         
WITH KEY smbln ls_extdata-mblnr
                  smblp 
ls_extdata-zeile
                  sjahr 
ls_extdata-mjahr.
    ENDIF.
    IF sy-subrc IS INITIAL.
      MOVE-CORRESPONDING ls_extdata TO ls_migo_badi_example.
      MOVE-CORRESPONDING ls_xmseg   TO ls_migo_badi_example.
      APPEND ls_migo_badi_example TO lt_migo_badi_example.
    ENDIF.
  ENDLOOP.
* The data from external detail screen can be saved now:
  CHECK gt_extdata IS NOT INITIAL.
  CALL FUNCTION 'ZJIM_BADI_EXAMPLE_UPDATE_DATA' IN UPDATE TASK
    TABLES
      it_migo_badi_example lt_migo_badi_example.
* The data from external header screen can be saved now:
*  MOVE-CORRESPONDING is_mkpf TO gs_exdata_header.
*  CALL FUNCTION 'MIGO_BADI_EXAMPLE_UPDATE_HEAD' IN UPDATE TASK
*    EXPORTING
*      is_migo_badi_header_fields = gs_exdata_header.

ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~POST_DOCUMENT

 

METHOD IF_EX_MB_MIGO_BADI~RESET .
* Clear all internal data:
  CLEARgt_extdata,
         g_no_input,
         gs_exdata_header,
         g_cancel,
         g_line_id.

ENDMETHOD.                    "IF_EX_MB_MIGO_BADI~RESET

激活所有,运行T_code MIGO 就可以看到第一个图的效果了。

  • 3
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 'b'sap abap bapi、badi、区别' 的意思是什么? 这个问题的意思是要求解释 "bapi"、"badi" 和 "abap" 之间的区别。"abap" 是德国软件公司 SAP 开发的编程语言,用于开发 SAP 系统中的应用程序。"bapi" (Business Application Programming Interface) 是 SAP 系统中的一个功能模块,用于连接不同的 SAP 应用程序和传递数据。而 "badi" (Business Add-Ins) 则是一种钩子机制,允许在 SAP 系统中插入自定义代码,以增强系统的功能和灵活性。所以,虽然 "bapi" 和 "badi" 都是 SAP 系统中的编程接口,但它们的作用和实现方式是不同的。 ### 回答2: SAP ABAP是SAP的编程语言,是一种面向对象的编程语言,用于开发SAP系统的应用程序。而BAPI和BADI则是SAP ABAP的两种不同的编程方法。 BAPI是Business Application Programming Interface的缩写,是一组已定义的函数模块,用于与SAP系统进行交互。BAPI可以用来调用SAP系统中的标准功能模块,以实现对标准SAP应用程序的访问和修改,还可以通过自定义函数模块进行个性化定制。BAPI旨在使不同的系统和应用程序能够无缝地进行集成,使它们更加灵活和可扩展。 BADI是Business Add-ins的缩写,是一种钩子(hook)技术,用于扩展SAP系统的标准功能。BADI提供了一种平台来开发、实现和操作可插入业务功能,使用户可以轻松地定制和扩展SAP应用程序,而且不会影响到标准SAP系统。用户可以在不同的SAP系统中使用同一种BADI实现,这使得BADI具有极大的灵活性和可重用性。 总体来说,BAPI是SAP系统的开放接口,用于与外部系统集成和定制,而BADI则是在SAP系统中增加附加业务逻辑的一种方式。虽然它们都是SAP ABAP编程中的重要技术,但它们的应用场景和目的有所不同。 ### 回答3: SAP ABAP BAPI和BADISAP系统中两种不同的编程方式。BAPI(Business Application Programming Interface)是SAP系统中一种标准的用于开发对外接口的编程方式,而BADI(Business Add-In)是SAP系统中一种基于面向对象的扩展点的编程方式。 BAPI是一种标准化编程接口,它允许开发人员将SAP系统中的业务逻辑封装成可重复使用的程序集,这些程序集可以被任何其他系统或应用程序使用。使用BAPI开发的程序可以被称为SAP的Web服务或API,它们可以通过网络调用,实现不同系统之间的数据传输和业务逻辑交互。BAPI通过一些标准提供的接口,如RFC(远程函数调用)和IDoc(中间文档)来实现与外部应用程序的数据交互。 与之不同的是,BADI是在SAP应用程序内部定义的一个特定点,用于扩展标准SAP业务逻辑。BADI是基于面向对象编程的原则,允许开发人员在SAP业务流程中插入自定义逻辑。BADI具有良好的可维护性和灵活性,因此比其他的扩展点如User Exit更加强大。BADI通常为开发人员提供了一些固定的入口点,使其可以在SAP系统的不同流程中添加自定义逻辑以满足业务需求。BADI可以在程序运行时被动态调用,因此可以大大增加程序的可扩展性。 需要注意的是,虽然BAPI和BADI都是SAP系统中的编程方式,但是它们有着不同的应用前提和场景。BAPI是为了将SAP系统扩展到其他系统或平台而开发的,其应用场景一般限制于外部应用程序与SAP交互的数据传输;而BADI则主要用于对SAP系统内的特定点进行业务逻辑扩展,其应用场景则更加广泛。在实际开发中,开发人员需要根据具体应用场景的需求进行选择和应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值