ABAP ALV 单元格是否可更改

*&---------------------------------------------------------------------*
*& Report  ZTEST_CESHI
*&---------------------------------------------------------------------*
*&---------------------------------------------------------------------*
REPORT ztest_ceshi.

TYPE-POOLS: slis.

*- Fieldcatalog

DATA: it_fieldcat TYPE lvc_t_fcat.

DATA: x_fieldcat TYPE lvc_s_fcat.

DATA: x_layout TYPE lvc_s_layo.



"第1步:用操作具体单元的是否可编辑的内表和工作区



DATA: ls_edit    TYPE lvc_s_styl,

      lt_edit    TYPE lvc_t_styl,

      gr_alvgrid TYPE REF TO cl_gui_alv_grid.

"第2步:在内表定义添加字段,用于控制具体行的具体单元是否可编辑

DATA: BEGIN OF it_vbap OCCURS 0,

        vbeln LIKE vbap-vbeln,

        posnr LIKE vbap-posnr,

        style TYPE lvc_t_styl, "FOR DISABLE   单元格是否可更改

      END OF it_vbap.

DATA: ls_outtab LIKE LINE OF it_vbap.

SELECT vbeln  posnr

  UP TO 100 ROWS

  INTO CORRESPONDING FIELDS OF TABLE it_vbap

FROM vbap.



DATA:l_pos TYPE i VALUE 1.

CLEAR: l_pos.

l_pos = l_pos + 1.

x_fieldcat-seltext = 'VBELN'.

x_fieldcat-fieldname = 'VBELN'.

x_fieldcat-tabname = 'ITAB'.

x_fieldcat-col_pos = l_pos.

x_fieldcat-edit = 'X'.

x_fieldcat-outputlen = '10'.

x_fieldcat-ref_field = 'VBELN'.

x_fieldcat-ref_table = 'VBAK'.

APPEND x_fieldcat TO it_fieldcat.



CLEAR x_fieldcat.

l_pos = l_pos + 1.

x_fieldcat-seltext = 'POSNR'.

x_fieldcat-fieldname = 'POSNR'.

x_fieldcat-tabname = 'ITAB'.

x_fieldcat-col_pos = l_pos.

x_fieldcat-edit = 'X'.

x_fieldcat-outputlen = '5'.

APPEND x_fieldcat TO it_fieldcat.

CLEAR x_fieldcat.

l_pos = l_pos + 1.

********************************************************
PERFORM set_status_disabled USING 6 'VBELN'.
PERFORM set_status_disabled USING 6 'POSNR'.

INSERT LINES OF lt_edit INTO TABLE ls_outtab-style.

MODIFY it_vbap INDEX 6 FROM ls_outtab TRANSPORTING style .
********************************************************
x_layout-stylefname = 'STYLE'.

CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
  EXPORTING
    i_callback_program = sy-repid
    is_layout_lvc      = x_layout
    it_fieldcat_lvc    = it_fieldcat
  TABLES
    t_outtab           = it_vbap[]
  EXCEPTIONS
    program_error      = 1
    OTHERS             = 2.

IF sy-subrc NE 0.

  MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno

  WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.

ENDIF.


FORM set_status_disabled USING index TYPE sy-tabix  fieldname TYPE lvc_s_styl-fieldname .

  sy-tabix = index.

  ls_edit-fieldname = fieldname.

  ls_edit-style = cl_gui_alv_grid=>mc_style_disabled.  " 不可更改 mc_style_enabled 可更改

  ls_edit-style2 = space.

  ls_edit-style3 = space.

  ls_edit-style4 = space.

  ls_edit-maxlen = 10.

  INSERT ls_edit INTO TABLE lt_edit.



ENDFORM.

ALV单元格动态可编辑ABAP技术在ALV报表上的一个重要扩展。ALVABAP List Viewer)是SAP系统中常用的报表显示工具,可以方便地展示和处理大量的数据。但是在默认情况下,ALV报表的单元格是不可编辑的,用户只能查看报表数据而无法进行修改。 为了满足用户对报表数据进行动态修改的需求,开发人员通过对ALV控件进行扩展,使其支持单元格的动态可编辑功能。这样用户可以直接在报表上进行数据编辑,无需打开数据源进行修改。 实现ALV单元格动态可编辑的扩展需要进行如下步骤: 1. 定义ALV报表的显示结构。 首先,需要定义ALV报表的显示结构,包括字段名、字段类型、长度等信息。 2. 扩展ALV函数模块。 在ALV函数模块中,需要添加相应的功能模块来支持单元格的动态可编辑。通过修改ALV函数模块的代码,实现对报表数据的修改和保存。 3. 增加用户交互接口。 为了方便用户进行数据修改,可以在报表上添加一些用户交互接口,比如勾选框、输入框等。用户可以通过这些接口直接修改报表数据,并进行保存操作。 4. 编写逻辑处理程序。 最后,需要编写逻辑处理程序,处理用户的修改操作。这个程序会根据用户输入的数据,更新相应的报表数据,并将修改后的数据保存回数据库中。 通过以上步骤的扩展,用户可以实现在ALV报表中直接进行数据编辑的功能。这样,用户可以更加方便地进行数据修改和保存,提高工作效率。同时,ALV单元格动态可编辑的扩展也为定制化的报表需求提供了更多的灵活性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值