对于普通ABAP屏幕中的I / O域,我可以让它们像SELECT-OPTIONS一样吗?

时间:2012-11-12 17:20:16

标签: screen selection abap

我正在尝试为常规屏幕中的某个字段提供普通SELECT-OPTIONS的功能。

我在Designer中查看了该I / O域的所有属性,但我找不到任何内容。

我看到有一些多项选择的功能正在提供给我,但它并不完整,这意味着在提示中我不再能够使用F4直观地选择我的范围。

我正在努力实现的目标是什么?

2 个答案:

答案 0 :(得分:4)

您可以使用

SELECTION-SCREEN BEGIN OF SCREEN 100 AS SUBSCREEN.
SELECT-OPTIONS so_foo FOR baz-baz.
SELECTION-SCREEN END OF SCREEN 100.

然后将生成的屏幕包含在您的程序的子屏幕区域中。

答案 1 :(得分:3)

您可以使用功能模块FREE_SELECTIONS_INITFREE_SELECTIONS_DIALOG的组合。 (您可以通过放在dynpro上的按钮触发此操作)。功能模块有点复杂,但它们有在线文档。

要扩展dynpro以模拟报告选择屏幕中的选择选项,您可以显示所选数据第一行的低值和高值。

这是一个让你入门的例子(功能模块FREE_SELECTIONS_DIALOG的文档实际上包含一些示例代码):

report  ztest_free_seldiag.

data: lv_selid type RSDYNSEL-SELID.
data: lt_fld type table of RSDSFIELDS.
data: ls_fld type RSDSFIELDS.

ls_fld-tablename = 'T001'.
ls_fld-fieldname = 'BUKRS'.
append ls_fld to lt_fld.

call function 'FREE_SELECTIONS_INIT'
  EXPORTING
    KIND                           = 'F'
  IMPORTING
    SELECTION_ID                   = lv_selid
  TABLES
    FIELDS_TAB                     = lt_fld
 EXCEPTIONS
   FIELDS_INCOMPLETE              = 1
   FIELDS_NO_JOIN                 = 2
   FIELD_NOT_FOUND                = 3
   NO_TABLES                      = 4
   TABLE_NOT_FOUND                = 5
   EXPRESSION_NOT_SUPPORTED       = 6
   INCORRECT_EXPRESSION           = 7
   ILLEGAL_KIND                   = 8
   AREA_NOT_FOUND                 = 9
   INCONSISTENT_AREA              = 10
   KIND_F_NO_FIELDS_LEFT          = 11
   KIND_F_NO_FIELDS               = 12
   TOO_MANY_FIELDS                = 13
   DUP_FIELD                      = 14
   FIELD_NO_TYPE                  = 15
   FIELD_ILL_TYPE                 = 16
   DUP_EVENT_FIELD                = 17
   NODE_NOT_IN_LDB                = 18
   AREA_NO_FIELD                  = 19
   OTHERS                         = 20.
if sy-subrc <> 0.
* Implement suitable error handling here
  exit.
endif.

call function 'FREE_SELECTIONS_DIALOG'
  exporting
    selection_id                  = lv_selid
    TITLE                         = 'Select Company Code'
    AS_WINDOW                     = 'X'
    TREE_VISIBLE                  = ' '
* IMPORTING
*   WHERE_CLAUSES                 =
*   EXPRESSIONS                   =
*   FIELD_RANGES                  =
*   NUMBER_OF_ACTIVE_FIELDS       =
  tables
    fields_tab                    = lt_fld
 EXCEPTIONS
   INTERNAL_ERROR                = 1
   NO_ACTION                     = 2
   SELID_NOT_FOUND               = 3
   ILLEGAL_STATUS                = 4
   OTHERS                        = 5.
if sy-subrc <> 0.
  BREAK-POINT.
  exit.
endif.
相关问题