ABAP SM30视图 自定义搜索帮助

需求描述:

配置表中有字段“客户代码”和“银行账户”,其中“银行账户”需要自定义搜索帮助,根据“客户代码”带出对应BP主数据的银行账户供用户选择。

实现方式:

1. 在视图屏幕里定义POV事件

 2. Module代码如下

MODULE BANKN_F4HELP INPUT.
  DATA: LT_DYNPFIELDS TYPE STANDARD TABLE OF DYNPREAD,
        LS_DYNPFIELDS TYPE DYNPREAD,
        LT_RETURN     TYPE STANDARD TABLE OF DDSHRETVAL,
        LS_RETURN     TYPE DDSHRETVAL,
        LV_POVSTEPL   TYPE SY-STEPL,
        LV_INDEX      TYPE SY-STEPL.

* 获取本页当前行号
  CALL FUNCTION 'DYNP_GET_STEPL'
    IMPORTING
      POVSTEPL        = LV_POVSTEPL
    EXCEPTIONS
      STEPL_NOT_FOUND = 1.

* 当前行号 = TC(包括翻页)的首行行号 + 本页当前行号 - 1
  LV_INDEX = TCTRL_ZTSD051-TOP_LINE + LV_POVSTEPL - 1.

  CLEAR LT_DYNPFIELDS[].
  LS_DYNPFIELDS-FIELDNAME = 'ZTSD051-KUNNR'.
  LS_DYNPFIELDS-STEPL     = LV_INDEX.
  APPEND LS_DYNPFIELDS TO LT_DYNPFIELDS.
  CLEAR LS_DYNPFIELDS.

* 获取屏幕值(以防用户修改后未按回车)
  CALL FUNCTION 'DYNP_VALUES_READ'
    EXPORTING
      DYNAME               = SY-REPID
      DYNUMB               = SY-DYNNR
      TRANSLATE_TO_UPPER   = 'X'
    TABLES
      DYNPFIELDS           = LT_DYNPFIELDS
    EXCEPTIONS
      INVALID_ABAPWORKAREA = 1
      INVALID_DYNPROFIELD  = 2
      INVALID_DYNPRONAME   = 3
      INVALID_DYNPRONUMMER = 4
      INVALID_REQUEST      = 5
      NO_FIELDDESCRIPTION  = 6
      INVALID_PARAMETER    = 7
      UNDEFIND_ERROR       = 8
      DOUBLE_CONVERSION    = 9
      STEPL_NOT_FOUND      = 10
      OTHERS               = 11.
  READ TABLE LT_DYNPFIELDS INTO LS_DYNPFIELDS INDEX 1.
  IF SY-SUBRC = 0.
    DATA(LV_KUNNR) = LS_DYNPFIELDS-FIELDVALUE.
  ENDIF.

* 查询客户银行信息
  SELECT PARTNER,
         BKVID,
         BANKS,
         BANKL,
         BANKN
    INTO TABLE @DATA(LT_BUT0BK)
    FROM BUT0BK
   WHERE PARTNER = @LV_KUNNR.

* 自定义搜索帮助
  CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
    EXPORTING
      RETFIELD        = 'BANKN'
      VALUE_ORG       = 'S'
    TABLES
      VALUE_TAB       = LT_BUT0BK
      RETURN_TAB      = LT_RETURN
    EXCEPTIONS
      PARAMETER_ERROR = 1
      NO_VALUES_FOUND = 2
      OTHERS          = 3.
  IF SY-SUBRC = 0.
    READ TABLE LT_RETURN INTO LS_RETURN INDEX 1.
    IF SY-SUBRC = 0.
      ZTSD051-BANKN = LS_RETURN-FIELDVAL.
    ENDIF.
  ENDIF.

ENDMODULE.

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP中的自定义屏幕搜索帮助可以从字典中获得。 在ABAP中,字典是一个用于管理和维护数据库对象的中心存储库。字典是一种集成的数据结构,可以用于存储表、视图、数据元素、域和其他数据库对象的定义。 要创建自定义屏幕搜索帮助,我们首先需要在字典中创建一个数据元素。数据元素定义了一个可重用的数据类型,可以用于在屏幕对话框中输入、输出和处理数据。在创建数据元素时,我们需要指定其数据类型、长度和其他属性。 接下来,在字典中创建一个域。域是数据元素的基本单位,它定义了一个数据元素的具体值范围、输入帮助和默认值等。在域定义中,我们可以指定一个搜索帮助,该搜索帮助将在屏幕对话框中提供数据输入帮助。 创建菜单路径:工具->ABAP字典,在打开的字典事务中,选择创建和编辑数据元素(SE11)。在创建数据元素时,我们可以指定数据类型(如CHAR、STRING、NUMC等)、长度、小数点位数和其他属性。 创建数据元素后,我们可以选择创建和编辑域(SE11)。在域定义中,我们可以指定值范围、输入帮助和默认值等。在输入帮助选项中,我们可以选择一个搜索帮助程序,该程序将在屏幕对话框中提供数据输入帮助。 通过将搜索帮助与数据元素和域相结合,我们可以在ABAP屏幕对话框中实现自定义屏幕搜索帮助。当用户在屏幕上输入数据时,他们可以通过搜索帮助来选择合适的值,并将其自动填充到相关字段中。 总之,ABAP中的自定义屏幕搜索帮助可以通过在字典中创建数据元素和域来实现。通过指定搜索帮助程序,我们可以在屏幕对话框中为用户提供数据输入帮助,并提高数据输入的准确性和效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值