1. 为什么我们需要自定义选择框?聊聊原生ALV的“痛点”
做SAP开发的朋友,尤其是经常和Function ALV打交道的,肯定遇到过这样的场景:业务用户看着满屏的数据,想勾选其中几行进行批量审批、批量过账或者批量删除。这时候,他们第一反应就是去找那个“选择框”。但原生的ALV Grid,那个选择模式用起来总感觉有点“隔靴搔痒”。要么是得先点一下行首那个小三角进入选择模式,操作起来不直观;要么就是全选逻辑不够灵活,用户想要一个清清楚楚、明明白白的复选框列,就像在Excel里操作一样简单直接。
我经历过好几次,用户直接跑过来说:“你们这个列表能不能加一列勾选框啊?我们想自己选,现在这个不好用。” 这其实就是最朴素的业务需求。原生的多行选择,对于非技术背景的用户来说,学习成本有点高,而且一旦数据刷新或者滚动,选择状态可能就丢了,体验确实不够友好。所以,我们作为开发,就得想办法在ALV里“画”出一列实实在在的复选框,并且配上“全选”和“取消全选”的按钮,让操作变得傻瓜式。这不仅仅是加个字段那么简单,它涉及到字段属性的动态控制、用户交互事件的捕获,以及数据状态的同步,是一套组合拳。做好了,用户满意度直线上升;做不好,可能就是频繁的运维支持电话。接下来,我就把自己在项目里摸爬滚打总结出来的方法,掰开揉碎了讲给你听。
2. 核心基石:用Fieldcat精细控制你的选择框列
想要在ALV里显示一列可以打勾的框,关键就在于我们构建字段目录(Field Catalog)的时候,对这个特殊的字段进行“化妆”和“授权”。这个字段,通常我们在内表里会定义一个SEL或者CHECKBOX这样的字段,类型就用CHAR1,用来存放‘X’(选中)或‘’(未选中)。光有内表字段还不够,必须通过Fieldcat告诉ALV:“嘿,这个字段请用复选框的样式显示,并且允许用户编辑它。”
这里有个我常用的宏定义技巧,能让字段定义变得清晰又不容易出错。先定义好结构,然后用宏来批量添加字段并设置属性。重点来了,当循环到我们的选择框字段(比如字段名是‘SEL’)时,一定要设置两个关键属性:gs_fieldcat-checkbox = 'X' 和 gs_fieldcat-edit = 'X'。第一个属性checkbox就是魔法开关,它让ALV把这个字段渲染成我们熟悉的方框打勾样式,而不是普通文本。第二个属性edit同样至关重要,它赋予了这列单元格可编辑的能力。没有这个,用户点破鼠标也没法勾选。
我刚开始做的时候,就忘了设edit属性,结果复选框是显示出来了,但怎么点都没反应,排查了半天才发现是这里漏了。所以,这两个属性是“黄金搭档”,缺一不可。另外,为了让界面更友好,我们通常会把这一列的列标题(scrtext_m)设置成“选择”或者“勾选”,并且通过col_p


118

被折叠的 条评论
为什么被折叠?



