模拟Select-Options对象实现多项数据输入功能
模拟Select-Options对象实现多项数据输入功能
Select-Options对象可以同时输入多项值并将所输入数据存入内表以供程序使用,不过Select-Options的功能有一定的局限性,它所能显示信息的长度是固定的,对于一些较长的文本,会因为输出长度过短而影响显示效果(如地址信息)。本例将以邮件地址输入字段为例,创建一个长度为50的可输入多值的文本对象。
本例中需要定义一个隐藏的Select-Options对象,用于保存实际输入数据。需要定义一个够长的文本框及一个多值输入按钮作为数据传递的接口。数据会通过所定义的文本框传递到隐藏的Select-Options对象中,并通过改变多值输入按钮上的图标样式来表示该对象中是否存在数据。
相关函数:
COMPLEX_SELECTIONS_DIALOG:开启输入多值对话框
- REPORT ZR_EXAMPLE_04 .
- TYPE-POOLS: ICON. "按钮上显示图标时需要调用该类库
- DATA: L_COUNT TYPE I. "用于计算内表数值总数
- DATA: LMAIL(50) TYPE C. "定义Mail地址输入变量长度及类型
- *定义屏幕元素及文本元素(参考第7章)
- SELECTION-SCREEN: BEGIN OF BLOCK ALV WITH FRAME TITLE TEXT-002.
- SELECTION-SCREEN: BEGIN OF LINE.
- SELECTION-SCREEN: COMMENT (14) TEXT-001.
- PARAMETERS: MAILCOPY LIKE LMAIL.
- SELECTION-SCREEN: PUSHBUTTON 63(5) PUBU USER-COMMAND MAILBUTT.
- SELECTION-SCREEN: END OF LINE.
- SELECTION-SCREEN: END OF BLOCK ALV.
- DATA: MAILTYPE TYPE C VALUE ''.
- *定义一隐藏的SELECT-OPTIONS用于保存输入值
- SELECT-OPTIONS: MAILADD FOR LMAIL NO-DISPLAY .
- AT SELECTION-SCREEN OUTPUT.
- CLEAR L_COUNT.
- DESCRIBE TABLE MAILADD LINES L_COUNT.
- *判断内表是否有值来设置按钮图标
- IF L_COUNT > 1.
- WRITE ICON_DISPLAY_MORE AS ICON TO PUBU.
- ELSE.
- WRITE ICON_ENTER_MORE AS ICON TO PUBU.
- ENDIF.
- AT SELECTION-SCREEN.
- CLEAR L_COUNT.
- DESCRIBE TABLE MAILADD LINES L_COUNT.
- *实现内表与文本元素间的值传递
- IF NOT MAILCOPY IS INITIAL AND MAILADD[] IS INITIAL.
- MAILADD-LOW = MAILCOPY.
- APPEND MAILADD.
- ENDIF.
- IF L_COUNT = 1.
- REFRESH MAILADD.
- CLEAR MAILADD.
- IF NOT MAILCOPY IS INITIAL.
- MAILADD-LOW = MAILCOPY.
- APPEND MAILADD.
- ENDIF.
- ENDIF.
- IF L_COUNT > 1 .
- IF MAILCOPY IS INITIAL.
- DELETE MAILADD INDEX 1.
- ELSE.
- MAILADD-LOW = MAILCOPY.
- MODIFY MAILADD INDEX 1 TRANSPORTING LOW.
- ENDIF.
- ENDIF.
- *在单击按钮的事件时调用输入多值输入对话框
- IF SY-UCOMM = 'MAILBUTT'.
- PERFORM SHOW_BOX.
- ENDIF.
- *---------------------------------------------------------------------*
- * 调用多值输入对话框 *
- *---------------------------------------------------------------------*
- FORM SHOW_BOX.
- TYPE-POOLS AQADH .
- DATA: TAB_AND_FIELD TYPE RSTABFIELD.
- TAB_AND_FIELD-TABLENAME = 'ADR6'.
- TAB_AND_FIELD-FIELDNAME = 'SMTP_ADDR'.
- *该函数将输入值传递给内表
- CALL FUNCTION 'COMPLEX_SELECTIONS_DIALOG'
- EXPORTING
- TEXT = 'SET E-Mail To '
- TAB_AND_FIELDTAB_AND_FIELD = TAB_AND_FIELD
- TABLES
- RANGE = MAILADD[]
- EXCEPTIONS
- NO_RANGE_TAB = 1
- CANCELLED = 2
- INTERNAL_ERROR = 3
- OTHERS = 4.
- *将内表首行值传给文本对象,显示在屏幕上
- IF NOT MAILADD[] IS INITIAL.
- READ TABLE MAILADD INDEX 1.
- MAILCOPY = MAILADD-LOW.
- ELSE.
- MAILCOPY = ''.
- ENDIF.
- ENDFORM
程序输出界面如图16-4所示。
|
| 图16-4 自定义多值输入文本对象执行界面 |
模拟Select-Options对象实现多项数据输入功能的更多相关文章
- BarTender中如何调整数据输入表单的大小?
BarTender中的表单设计,是一个简单而又复杂的操作.简单的是它提供很多实用的工具,帮助用户实现更多的功能,复杂的是要对其进行排版设计,这就要看小伙伴们的个人要求高低了. 自定义数据输入表单时,你 ...
- 如何利用javascript获取表单中select下拉列表中所选中项的值value
1.html代码如下: <html> <head> </head> <body> <form name="form1" id= ...
- .NET Core采用的全新配置系统[3]: “Options模式”下的配置是如何绑定为Options对象
配置的原子结构就是单纯的键值对,并且键和值都是字符串,但是在真正的项目开发中我们一般不会单纯地以键值对的形式来使用配置.值得推荐的做法就是采用<.NET Core采用的全新配置系统[1]: 读取 ...
- TFS工作项数据统计及相关数据库结构分析
今天为客户的质量管理部门人员提供TFS咨询过程中,客户的质量管理专家基于TFS提出了一个比较棘手的数据统计需求.需求是这样,客户的数十个软件项目通过质量管理部按照年度版本计划进行软件产品系统的发布,因 ...
- Flexigrid从对象中加载数据
(有问题,在找…………) Flexigrid是用来动态加载数据的一种比较好(老)的Jquery表插件,然后有些时候,我们需要其从本地或者jQuery对象中加载数据,比如有这么个需求,页面显示中有两个表 ...
- resultset 对象获取行字段数据时报:java.sql.SQLException: Column 'id' not found.
resultset 对象获取行字段数据时报:java.sql.SQLException: Column 'id' not found. 代码: String sql="SELECT d.co ...
- 【转】asp.net中利用session对象传递、共享数据[session用法]
来自:http://blog.unvs.cn/archives/session-transfer-method.html 下面介绍Asp.net中利用session对象传递.共享数据用法: 1.传递值 ...
- asp.net中利用session对象传递、共享数据[session用法]
下面介绍Asp.net中利用session对象传递.共享数据用法: 1.传递值: 首先定义将一个文本值或单独一个值赋予session,如下: session[“name”]=textbox1.text ...
- select options常用操作
1.判断select选项中 是否存在Value="value"的option元素 function jsSelectIsExitItem(objSelect,objItemValu ...
随机推荐
- POJ 1012 Joseph
Joseph Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44650 Accepted: 16837 Descript ...
- bower 新建.bowerrc文件
Twitter工程师团队推出了Bower,这是一个针对Web开发的包管理器.该工具主要用来帮助用户轻松安装CSS.JavaScript.图像等相关包,并管理这些包之间的依赖. 随着网页功能变得越来越复 ...
- ecshop的订单状态
ecshop的订单状态都是在ecs_order_info表中的字段里. 订单状态 未确认 取消 确认 已付款 配货中 已发货 已收货 退货 order_status 0 2 1 1 1 5 5 4 s ...
- Windows无法安装到GPT分区形式磁盘,怎么办?
有时候用原版系统镜像安装windows系统时,会提示“windows无法安装到这个磁盘.选中的磁盘采用GPT分区形式”,导致安装失败,下面就来讲解一下如何解决. 步骤阅读 百度经验:jingyan ...
- mysql 语句case when
CREATE TABLE `lee` (`id` int(10) NOT NULL AUTO_INCREMENT, `name` char(20) DEFAULT NULL, `birthday` d ...
- Asp.net Mvc4 基于Authorize实现的模块权限验证方式
在MVC中,我们可以通过在action或者controller上设置Authorize[Role="xxx"] 的方式来设置用户对action的访问权限.显然,这样并不能满足我们的 ...
- Hadoop入门进阶课程9--Mahout介绍、安装与应用案例
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,博主为石山园,博客地址为 http://www.cnblogs.com/shishanyuan ...
- intellij 调试方法
intellij 调试方法 转自 http://www.th7.cn/Program/net/201410/296492.shtml
- 开放产品开发(OPD):产品负责人的工作原则和方法
月26日我将在2014 WOT全球软件技术峰会做相关的一个主题演讲[产品负责人的工作原则和方法],个原则和相应的一些方法. 以下是本次分享内容: 完整版如下,如果你喜欢想下载的话,点击 http:// ...
- sqlite3存储格式
本篇介绍sqlite3数据库文件的存储格式.通过阅读源读源代码可以知道sqlite的设计思想.一个sqlite数据库文件对应着一个数据库.sqlite将数据库文件划分大小一致的存储(以区分内存)页面, ...