通过  gs_layout-box_fname  = 'SEL'.设置选择行,不能取到 SEL列的值

找资料:作者:f122300349 
来源:CSDN 
原文:https://blog.csdn.net/f122300349/article/details/5517154 
版权声明:本文为博主原创文章,转载请附上博文链接

带选择列,是个什么概念,就是在ALV的表单主体前面多了一列可供选择的,具体就看下图:

这个就是对应的选择列,通过这个可以实现对ALV数据的选择,在调用函数的ALV和面向对象的ALV实现方法存在差异,下面讲两者的方法:

1)调用函数的ALV。

通过 SLIS_LAYOUT_ALV-BOX_FIELDNAME的字段来设置,这个字段的值对应的是输出内表的一个字段名字(专门用于标记选择哪些列,选中的为‘X’),其实这种实现方法就跟平时我们增加一列复选择框用于选择的方法大致一样的,但是这种方法选择的方式比较快。
2)面向对象的ALV。

通过结构 LVC_S_LAYO-SEL_MODE的了段来设置,这个字段对应的值有以下5个:
     1、sapce,等同于B,默认的设置。

2、A(行与列的选择,无法选择单元格)。

3、B(单选,不可以多选行,不可以多选单元格)。

4、C(多选行、列,不可以多选单元格)。

5、D(多选行、列,还可以多选单元格)。

只有设置的值为‘C’或者‘D’带选择列才可以显示出来,其它值一概不行。如果ALV输出有列是可以编辑,则会覆盖了sel_mode的值,带选择列也会显示出来的哦。

通过与1)种方法比较,很容易发现2)种方法没有通过内表的一个字段值来记录哪些值没选中了,那我们如何知道哪些列被选中了呢???有办法了,通过CL_GUI_ALV_GRID-> GET_SELECTED_ROWS的方法来获取选中列对应的在输出内表中的行ID了,具体就看下面的例子了:

DATA : LT_ROW TYPE  LVC_T_ROID,    "内表          
           LS_ROW TYPE  LVC_S_ROID.    "工作区

ALV_GRID1->GET_SELECTED_ROWS
    IMPORTING
      ET_ROW_NO = LT_ROW.

LOOP  AT  LT_ROW INTO  LS_ROW.
      READ  TABLE  T_OUTPUT INDEX  LS_ROW-ROW_ID.
      IF  SY-SUBRC EQ  0 .
        T_ARG-PASS = 0 .
        APPEND  T_OUTPUT TO  T_PRINT1.
      ENDIF .
      CLEAR  T_OUTPUT.
    ENDLOOP .
---------------------
作者:f122300349
来源:CSDN
原文:https://blog.csdn.net/f122300349/article/details/5517154
版权声明:本文为博主原创文章,转载请附上博文链接!

  DATA: lv_row TYPE i,
lv_col TYPE i.
DATA: ls_row_no TYPE lvc_s_roid,
ls_row_info TYPE lvc_s_row,
ls_col_info TYPE lvc_s_col.
* CALL METHOD grf_grid->check_changed_data.
*
* CALL METHOD grf_grid->get_current_cell
* IMPORTING
* e_row = lv_row
* e_col = lv_col.
* CALL METHOD grf_grid->get_scroll_info_via_id
* IMPORTING
* es_row_no = ls_row_no
* es_row_info = ls_row_info
* es_col_info = ls_col_info. **获取所选的多行
DATA: lt_row TYPE lvc_t_roid, "内表
ls_row TYPE lvc_s_roid. "工作区 CALL METHOD grf_grid->get_selected_rows
IMPORTING
et_row_no = lt_row.
LOOP AT lt_row INTO ls_row.
READ TABLE gt_doc INTO gs_doc INDEX ls_row-row_id.
IF sy-subrc EQ .
gs_doc-sel = 'X'.
MODIFY gt_doc FROM gs_doc INDEX ls_row-row_id.
ENDIF .
ENDLOOP . gv_save_code = gv_ok_code.
CLEAR: gv_ok_code.
CASE gv_save_code. WHEN 'BACK' OR 'EXIT' OR 'CANC'.
LEAVE TO SCREEN . WHEN 'DOC'.
PERFORM frm_call_mb01. "调用过账 ENDCASE. CALL METHOD grf_grid->refresh_table_display. CALL METHOD grf_grid->set_scroll_info_via_id
EXPORTING
is_row_info = ls_row_info
is_col_info = ls_col_info
is_row_no = ls_row_no.

实现可以选择行

面向对象ALV选择列的更多相关文章

  1. 调用函数的ALV、面向对象的ALV设置带选择列

    这个就是通过对应的选择列,实现对ALV数据的选择,在调用函数的ALV和面向对象的ALV实现方法存在差异,下面讲两者的方法:1)调用函数的ALV.   通过 SLIS_LAYOUT_ALV-BOX_FI ...

  2. jqGrid选择列控件向右拖拽超出边界处理

    jqGrid选择列控件向右拖拽超出边界处理 $("#tb_DeviceInfo").jqGrid('navButtonAdd', '#jqGridPager', {         ...

  3. Devexpress GridControl中 repositoryItemCheckEdit作为选择列以及作为显示列的使用方法

    一.在gridcontrol列表控件中使用单选框作为选择列,这里有两种方式. 方式一:选择gridcontrol控件的Run Designer按钮,添加一列,设置该列的ColumnEdit为check ...

  4. scikit-learn预处理实例之一:使用FunctionTransformer选择列

    本例展示怎样在一个管道中使用FunctionTransformer.如果你知道你的数据集的第一主成分与分类任务无关,你可以使用FunctionTransformer选取除PCA转化的数据的第一列之外的 ...

  5. pandas 选择列或者添加列生成新的DataFrame

    选择某些列 import pandas as pd # 从Excel中读取数据,生成DataFrame数据 # 导入Excel路径和sheet name df = pd.read_excel(exce ...

  6. ALV行 列颜色设置

    ALV的颜色设置分为3种:行.列.单元格.   1.列颜色的设置   在 slis_t_fieldcat_alv-emphasize 中,写入需要的颜色代码.   Eg:   DATA: fc TYP ...

  7. mysql选择列建立索引选择

    1. 选择Where子句中筛选性好的列,即列中数据大量不重复 2. 索引名最好 idx_ 开头 3. 包含在 Order by ; Group By; Distinct 中的字段可以添加索引,可以提高 ...

  8. GridControl 选择列、复选框全选(下)

    功能:        删除选中行 前台调用: string str=""; GridDelete(gv, "chk", out str); MessageBox ...

  9. GridControl 选择列、复选框全选(上)

    说明: GirdControl 中添加一列,这一列不是写在数据库中的,而是代码中添加的. 图示: 底层类代码: #region GridControl 全选 /// <summary> / ...

随机推荐

  1. 2.Storm集群部署及单词统计案例

    1.集群部署的基本流程 2.集群部署的基础环境准备 3.Storm集群部署 4.Storm集群的进程及日志熟悉 5.Storm集群的常用操作命令 6.Storm源码下载及目录熟悉 7.Storm 单词 ...

  2. <a>标签的target 属性 全局作用

    局部(或全局)设置<a>标签的target属性           对于超链接<a>标签,target属性的设置是比较关键的,在不同的用户场景下选用适合的新页面载入方式,可以大 ...

  3. PAT Advanced 1071 Speech Patterns (25 分)

    People often have a preference among synonyms of the same word. For example, some may prefer "t ...

  4. Codeforces 567D - One-Dimensional Battle Ships - [树状数组+二分]

    题目链接:https://codeforces.com/problemset/problem/567/D 题意: 在一个 $1 \times n$ 的网格上,初始摆放着 $k$ 只船,每只船的长度均为 ...

  5. 如何用pycharm 控制远程服务器来跑代码!!!!!!!!!!!!非常牛逼

    2019-09-04,10点58 想弄一个pycharm的插件,就是用deployment同步代码的时候,在pycharm里面运行代码,的时候本机不动,而是远程服务器运行,然后把结果返回!!!!!!挺 ...

  6. BZOJ 1778: [Usaco2010 Hol]Dotp 驱逐猪猡 (高斯消元)

    题面 题目传送门 分析 令爆炸概率为PPP.设 f(i)=∑k=0∞pk(i)\large f(i)=\sum_{k=0}^{\infty}p_k(i)f(i)=∑k=0∞​pk​(i),pk(i)p ...

  7. 3、获取Class对象的三种方式

    3.获取Class对象的三种方式 要想对字节码文件进行解刨,必须要有字节码文件对象 Object类中的getClass方法 通过对象静态属性 .class来获取对应的Class对象 只要通过给定类的字 ...

  8. FFmpeg处理音视频流程学习笔记

    原文作者:一叶知秋0830 链接:https://www.jianshu.com/p/1b715966af50 FFmpeg处理音视频完整流程包括5个阶段(输入文件—>编码数据包—>解码后 ...

  9. python 赋值魔法

    序列解包: >>> x,y,z = 1, 2, 3>>> print(x, y, z)1 2 3 >>> a,b, *reset = [1,2,3 ...

  10. 洛谷 P3382 【模板】三分法(三分 二分)

    P3382 [模板]三分法 题目提供者HansBug 难度 普及/提高- 题目描述 如题,给出一个N次函数,保证在范围[l,r]内存在一点x,使得[l,x]上单调增,[x,r]上单调减.试求出x的值. ...