WDA学习(25):DateNavigator使用
1.18 UI Element:Date Navigator使用
本实例测试创建Date Navigator;
1.创建Component,View: V_DATE_NAVIGATOR;
2.创建Context节点;
创建NODE: NODE_DATENAV, Cardinality:1..1;
创建Attribute:SELECTION_MODE,类型WDUI_DATE_SELECTION_MODE;
创建Attribute: FIRST_DAY_OF_WEEK,类型WDUI_DAY_OF_WEEK;
创建Attribute: FIRST_SELECTED_DATE,类型D;
创建Attribute:LAST_SELECTED_DATE,类型D;
创建Attribute: MONTH_PER_COLUMN,类型I;
创建Attribute: MONTH_PER_ROW,类型I;
创建Attribute: START_WITH,类型D;
创建NODE:NODE_MARKING,Cardinality:0..n;
创建Attribute:DATE,类型D;

3.创建Layout UI Element;
创建UI Element:Tray,ID:TRAY1,包含一些输入参数UI Element;
创建UI Element:Toolbar;
创建UI Element:ToolbarButton,绑定Action:APPLY;
创建UI Element:Label;
创建UI Element:DropDownByKey,ID: INP,selectedKey绑定Context的Attribute: V_DATE_NAVIGATOR.NODE_DATENAV.FIRST_DAY_OF_WEEK;
创建UI Element:InputField,ID:INP1,value绑定Context的Attribute: V_DATE_NAVIGATOR.NODE_DATENAV.FIRST_SELECTED_DATE;
创建UI Element:InputField,ID:INP2,value绑定Context的Attribute: V_DATE_NAVIGATOR.NODE_DATENAV.LAST_SELECTED_DATE;
创建UI Element:InputField,ID:INP3,value绑定Context的Attribute: V_DATE_NAVIGATOR.NODE_DATENAV.MONTH_PER_COLUMN;
创建UI Element:InputField,ID:INP4,value绑定Context的Attribute:
V_DATE_NAVIGATOR.NODE_DATENAV.MONTH_PER_ROW;
创建UI Element:DropDownByKey,ID:INP5,selectedKey绑定Context的Attribute:
V_DATE_NAVIGATOR.NODE_DATENAV.SELECTION_MODE;
创建UI Element:InputField,ID:INP6,value绑定Context的Attribute: V_DATE_NAVIGATOR.NODE_DATENAV.START_WITH;
创建UI Element:DateNavigator;
设置Properties
firstDayOfWeek:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.FIRST_DAY_OF_WEEK;
firstSelectedDate:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.FIRST_SELECTED_DATE;
lastSelectedDate:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.LAST_SELECTED_DATE;
monthsPerColumn:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.MONTH_PER_COLUMN;
monthsPerRow:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.MONTH_PER_ROW;
selectionMode:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.SELECTION_MODE;
startsWith:绑定Attribute,V_DATE_NAVIGATOR.NODE_DATENAV.START_WITH;
onDaySelect:绑定Action,SEL_DAY;
onMonthSelect:绑定Action,SEL_MONTH;
onStartDateChanged:绑定Action,CHANGE_START_DAY;
onWeekSelect:绑定Action,SEL_WEEK;
创建UI Element:DateNavigatorMarking;
设置Properties
dataSource:绑定V_DATE_NAVIGATOR.NODE_MARKING;
date:绑定NODE_MARKING.DATE;

4.创建Method页签方法;
创建INIT_PROPER方法,初始化DateNavigator的属性参数,WDDOINIT方法中调用;
代码实例:
DATA:lo_node TYPE REF TO if_wd_context_node.
DATA:lo_element TYPE REF TO if_wd_context_element.
DATA:lv_date TYPE D. lv_date = sy-datum.
"获取节点
lo_node = wd_context->get_child_node( wd_this->wdctx_node_datenav ).
lo_element = lo_node->get_element( ).
lo_element->set_attribute(
EXPORTING
name = 'FIRST_SELECTED_DATE'
value = lv_date
).
lo_element->set_attribute(
EXPORTING
name = 'LAST_SELECTED_DATE'
value = lv_date
).
lo_element->set_attribute(
EXPORTING
name = 'MONTH_PER_COLUMN'
value = 1
).
lo_element->set_attribute(
EXPORTING
name = 'MONTH_PER_ROW'
value = 2
).
lo_element->set_attribute(
EXPORTING
name = 'START_WITH'
value = lv_date
).
实现Action: SEL_DAY,日期选择;
DATA:lo_node TYPE REF TO if_wd_context_node.
DATA:lo_element TYPE REF TO if_wd_context_element.
DATA:lt_marking TYPE wd_this->elements_node_marking.
DATA:ls_marking TYPE wd_this->element_node_marking.
DATA:lv_date TYPE string.
"获取选择的日期
lv_date = wdevent->get_string( name = 'DAY' ).
"获取节点
lo_node = wd_context->get_child_node( wd_this->wdctx_node_marking ).
lo_node->get_static_attributes_table( IMPORTING table = lt_marking ). READ TABLE lt_marking INTO ls_marking WITH KEY date = lv_date.
IF sy-subrc = 0.
DELETE TABLE lt_marking FROM ls_marking.
ELSE.
ls_marking-date = lv_date.
APPEND ls_marking TO lt_marking.
ENDIF.
lo_node->bind_table( new_items = lt_marking set_initial_elements = abap_true ).
实现Action:SEL_MONTH,选择月份;
DATA:lo_event TYPE REF TO cl_wd_custom_event.
DATA:lv_year TYPE string.
DATA:lv_month TYPE string.
lo_event = wdevent.
lv_year = wdevent->get_string( name = 'YEAR' ).
lv_month = wdevent->get_string( name = 'MONTH' ).
lv_year = 'select month:' && lv_year && lv_month.
wd_comp_controller->show_msg( msg = lv_year msg_type = 'S' ).
实现Action: SEL_WEEK,选择周;
DATA:lo_event TYPE REF TO cl_wd_custom_event.
DATA:lv_year TYPE string.
DATA:lv_week TYPE string.
DATA:lv_first_day TYPE string. lo_event = wdevent.
lv_year = wdevent->get_string( name = 'YEAR' ).
lv_week = wdevent->get_string( name = 'WEEK' ).
lv_first_day = wdevent->get_string( name = 'FIRST_DAY' ).
lv_year = 'select week:' && lv_year && '年第' && lv_week && '周' && 'first day:' && lv_first_day.
wd_comp_controller->show_msg( msg = lv_year msg_type = 'S' ).
实现Action:CHANGE_START_DAY,修改start day;
代码实例:
DATA:lo_event TYPE REF TO cl_wd_custom_event.
DATA:lv_date TYPE string. lv_date = wdevent->get_string( name = 'START_DATE' ).
lv_date = 'change start date:' && lv_date.
wd_comp_controller->show_msg( msg = lv_date msg_type = 'S' ).
5.执行显示

WDA学习(25):DateNavigator使用的更多相关文章
- django学习-25.admin管理后台里:把表名称和表字段名称的展示值都由英文显示改为由中文显示
目录结构 1.前言 2.完整的操作步骤 2.1.第一步:修改模型类Article 2.2.第二步:重启服务 2.3.第三步:退出登录并再次成功登陆admin管理后台 2.4.第四步:查看最新的表名称展 ...
- iOS 学习 - 25 ImageIO 播放 GIF
一.给原生的 UIImageView 添加类别来支持 GIF 播放 GIF 动态图片文件中包含了一组图片及信息,信息主要记录着每一帧图片播放的时间,我们如果获取到了 gif 文件中所有的图片同时又获取 ...
- 【Java EE 学习 25 下】【网上图书商城js小技术点总结】
1.日历控件的使用 日历控件源代码: /** * add auto hide when mouse moveout * * @version 1.0.1 * @date 2010-11-23 * @a ...
- 【Java EE 学习 25 上】【网上图书商城项目实战】
一.概述 1.使用的jdk版本:1.6 2.java EE版本:1.6 3.指导老师:传智播客 王建 二.小项目已经实现的功能 普通用户: 1.登陆 2.注册 3.购物 4.浏览 管理员用户(全部管理 ...
- [游戏学习25] MFC 橡皮筋画线效果
>_<:这是给出窗口内外不同情况的处理展示的例子. >_<:MouseCap.h #include<afxwin.h> class CMyApp :public C ...
- C++学习25 纯虚函数和抽象类
在C++中,可以将成员函数声明为纯虚函数,语法格式为: ; 纯虚函数没有函数体,只有函数声明,在虚函数声明结尾加上=0,表明此函数为纯虚函数. 最后的=0并不表示函数返回值为0,它只起形式上的作用,告 ...
- swift 学习- 25 -- 协议 02
// 通过扩展添加协议一致性 // 即便无法修改源代码, 依然可以通过扩展 令已有类型遵循并符合协议, 扩展可以为已有类型添加属性, 方法, 下标 以及构造器, 因此可以符合协议中的相应要求 // 注 ...
- Python学习(25):Python执行环境
转自 http://www.cnblogs.com/BeginMan/p/3191856.html 一.python特定的执行环境 在当前脚本继续进行 创建和管理子进程 执行外部命令或程序 执行需要输 ...
- Python学习-25.Python中的分数
在Python中,不止有浮点数(float),而且还有分数(Fraction)这个类型. 要使用分数,必须引入一个模块. import fractions 然后就可以声明一个分数了 x = fract ...
- python学习(25) BeautifulSoup介绍和实战
BeautifulSoup是python的html解析库,处理html非常方便 BeautifulSoup 安装 pip install beautifulsoup4 BeautifulSoup 配合 ...
随机推荐
- 前端实现电子签名(web、移动端)通用组件(canvas实现)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- oracle的dblink创建连接查询及使用
https://www.cnblogs.com/muhai/p/15527463.html https://www.cnblogs.com/leipei2352/archive/2011/04/21/ ...
- django源码剖析(steup、runserver、生命周期)
工作上会经常用到不熟悉的第三方模块,大多数时候会选择看文档.百度谷歌.看源码等形式去把它用起来.几年工作经验下来源码看的不少了,但当面试被问到django的生命周期时,只能浅谈根据wsgi协议会走ap ...
- 4、kubesphere环境安装
安装步骤 选择4核8G(master).8核16G(node1).8核16G(node2) 三台机器,按量付费进行实验,CentOS7.9 安装Docker 安装Kubernetes 安装KubeSp ...
- 一、100ASK_IMX6ULL嵌入式裸板学习_LED实验(上)
LED实验 汇编的方式驱动LED /* *LED汇编实验 *创建者:Orange *2021年03月04日 */ .global _start @全局标号 _start: /*使能所有外设时钟 */ ...
- 【GROMACS】分子动力学模拟①——环境搭建
系统环境 Win11 22H2 企业版 开启虚拟化.window subsystem for liunx等虚拟机相关的功能 应用商店中安装WSL2 安装步骤 打开Ubuntu,输入sudo apt f ...
- MassTransit - .NET Core 的分布式应用程序框架
简介 MassTransit 是一个免费的.开源的.NET 分布式应用程序框架.MassTransit 使创建应用程序和服务变得容易,这些应用程序和服务利用基于消息的松散耦合异步通信来实现更高的可用性 ...
- Quartz 2D CGGradient与CGShading实现渐变的绘制
Quartz 提供了两种不透明的数据类型来创建渐变CGShading 和 CGGradient,你可以使用其中任何一个来创建轴向或径向渐变. 轴向渐变:沿着一个轴方向线性渐变 径向渐变:一个点为原型, ...
- BundleFusion_Ubuntu_Pangolin 安装的一些error
/usr/bin/ld: 找不到 -lEigen3::Eigen 解决方法:find_package(Eigen3 REQUIRED)为list(APPEND CMAKE_INCLUDE_PATH & ...
- Wix打包升级包
前面我们已经知道怎么制作一个完整安装包了,但我们的软件往往不能一次性就满足客户的需要,当客户需要我们给软件进行升级的时候,我们应该怎么做呢? 在这之前,我们有必要了解下Windows Installe ...