转自:https://www.jianshu.com/p/68c1592f1a87

WDA全称Web Dynpro for ABAP,也写作WD4A或WDA,是用于在ABAP环境中开发Web应用程序的SAP标准UI技术。 它由运行时环境和图形开发环境组成,其中包含集成在ABAP Workbench(SE80)中的特殊Web Dynpro工具。

本教程提供了开发一个WDA程序的分步指南。

目录:

  1. 创建WDA对象
  2. 创建视图
  3. 添加UI元素和视图
  4. 创建组件控制器上下文
  5. 数据映射
  6. 从组件控制器访问数据
  7. 定义导航模式
  8. 创建应用
  9. 测试WDA应用

1. 创建WDA对象

进入事务码SE80,在左侧对象框列表中选择“Web Dynpro组件/接口”,输入对象的名称“Z_TUTORIAL1”,然后回车,系统将询问是否创建此对象,单击“是”。

 
创建Z_TUTORIAL1

输入对象描述和要创建的视图名称,回车。将会出现一个要求分配包的对话框,这里选择本地对象。

 
输入描述

现在,WDA对象就创建好了。

 
WDA概览

2. 创建视图

视图包含用户与应用程序交互所需的UI元素,SAP提供了许多不同的类型的UI元素。

这里需要创建两个视图,第一个视图已经在创建对象的时候自动创建好了。

 
视图Start

我们再来创建一个Result视图。

 
创建Result视图
 
输入描述

保存并激活所有对象之后,就能看到下图了。

 
视图

3. 添加UI元素和视图

接下来,我们为Start视图构建用户界面。

如上图所示界面,在右侧找到ROOTUIELEMENTCONTAINER,右键选择“Inser Element”。

 
Inser Element

出现一个对话框,输入“Label1”,类型选择“LABEL”。

 
Label1

如此,再创建一个输入框和按钮。

 
输入框INPUT1
 
按钮BUTTON1

为 Label1 添加显示文本:Enter Your Name。

 
Enter Your Name

为BUTTON1添加显示文本:Continue。

 
Fill in Text

并未其创建事件触发,单击右侧新建按钮。

 
新建动作

输入如下信息,填写描述及输出,按回车。

 
Create Action

此时出现是否创建Outbound Plug,选择“是”。

 
Create Outbound Plug

点击“Inbound Plug”选项卡,并创建“FromResult”。

 
Inbound Plug

创建视图的上下文,单击“Context”选项卡,首先右键选择创建一个节点。

 
Create Node

弹出对话框,键入如下,回车。

 
Create Node

再在MAIN下创建一个属性,选择MAIN节点,右键创建。

 
Create Attribute

输入如下,回车。

 
Create Attribute

再回到Layout选项卡,给Input1元素映射到视图上下文。单击value旁边的小图标,然后从弹出的对话框选择NAME。

 
Define Context Binding

保存并激活所有对象。

仿照对Start视图的操作,为Result视图添加一个名为“TEXT1”的元素,类型为TextView。并添加一个名为“BUTTON1”的按钮,将动作指定为“Back”。

在Context选项卡,创建MAIN节点和NAME属性。

 
Context

来到Layout,创建TEXT1。

 
TEXT1

选择TEXT1的text字段,点击右边的小方块,弹出对话框后,选择NAME,回车。

 
NAME

在ROOTUIELEMENTCONTAINER创建一个BUTTON1按钮并为其添加显示文本“Back”和事件触发“Back”。

 
BUTTON1

在弹出的对话框填写如下,回车。在弹出的讯问中选择“是”。

 
image.png

在 Inbound Plugs 输入 FROMSTART。

 
FROMSTART

保存并激活全部对象。

4. 创建组件控制器上下文

通过组件控制器上下文控制数据的传递。

在COMPONENTCONTROLLER,为Context创建节点和属性。

 
COMPONENTCONTROLLER

节点MAIN。

 
Create Node

属性NAME。

 
Create Attribute

保存并激活全部对象。

5. 数据映射

数据映射是组件控制器将用多个视图数据连接起来。

双击左侧的 START 视图,在Context选项卡,右键单击视图控制器的MAIN节点,然后选择“Define Mapping”。

在弹出的对话框中选择MAIN。

 
Select Mapping from

为Result视图做同样的操作。

保存并激活所有对象。

6. 从组件控制器访问数据

用户将在START视图中输入数据,并在RESULT视图中显示改值。

来到RESULT视图,单击Methods选项卡,找到“WDDOMODIFYVIEW”方法,双击进入。在代码中键入空行,然后在上方工具栏选择“Web Dynpro Code Wizard”按钮(快捷键Ctrl+F7)。

 
Web Dynpro Code Wizard

通过选择上下文的按钮,在弹出的对话框选择NAME,回车两次。

 
Context Viewer

代码已生成。

 
Generated Code

在endmethod之前添加一段逻辑如下。

  CONCATENATE 'Welcome to WDA' LV_NAME INTO LV_NAME
SEPARATED BY SPACE. LO_EL_MAIN->SET_ATTRIBUTE(
EXPORTING
NAME = 'NAME'
VALUE = LV_NAME ).
 
METHOD WDDOMODIFYVIEW

回到 Method List ,找到 ONACTIONBACK 双击进入。在WD_THIS->FIRE_TOSTART_PLG之前插入空行,再次使用“Web Dynpro Code Wizard”按钮生产代码。

 
Web Dynpro Code Wizard

在WD_THIS->FIRE_TOSTART_PLG之前插入几行代码。

  CLEAR LV_NAME.

  LO_EL_MAIN->SET_ATTRIBUTE(
EXPORTING
NAME = 'NAME'
VALUE = LV_NAME ).

结果如图。

 
ONACTIONBACK

7. 定义导航模式

导航模式允许定义师徒之间的导航流。定义入站和出站插件提供的入口和出口点。导航连接定义视图的显示顺序。

双击窗口下的 Z_TUTORIAL1 ,然后将视图Result拉入Z_TUTORIAL1。

 
Windows Z_TUTORIAL1

结果如图。

 
Windows Z_TUTORIAL1

在ToResult上右键“创建导航连接”。

 
创建导航连接

在弹出的对话框中,“目标视图”输入框通过F4选择“RESULT”,回车。

 
选择导航目标

在ToStart上右键“创建导航连接”,在弹出的对话框中,“目标视图”输入框通过F4选择“START”,回车。

结果如图。

 
结果

保存并激活所有对象。

8. 创建应用

本程序是允许在浏览器中通过URL寻址和显示的WDA对象,通过右键单击左侧对象树中的WDA对象来创建应用程序。

 
创建DWA应用

输入描述,并保存为本地对象。

 
WDA描述

9. 测试WDA应用

此时在下方出现一个Web Dynpro 应用程序,打开后右键单击测试,就会弹出浏览器界面。

 
测试

在输入框输入一段文字,单击按钮。

 
Start界面

结果如图。

 
Result界面

至此,恭喜你完成了第一个WDA程序的创建。

错漏之处,欢迎指正。

WDA入门教程Ⅰ:Web Dynpro for ABAP 入门(转)的更多相关文章

  1. 《JavaScript语言入门教程》记录整理:入门和数据类型

    目录 入门篇 js介绍 历史 基本语法 数据类型 概述 null 和 undefined 数值 字符串 对象 函数 数组 本系列基于阮一峰老师的<JavaScrip语言入门教程>或< ...

  2. JSP/SERVLET入门教程--Servlet 使用入门

    现在的JSP书籍有的是直接讲述JSP的使用,然后再讲解SERVERLET的使用;也有书籍是先讲述SERVERLET的使用,然后讲解JSP使用.个人认为第二种相对好一些,至于原因大家可以在学习体会到!所 ...

  3. Unity3D开发入门教程(二)—— Lua入门

    五邑隐侠,本名关健昌,12年游戏生涯. 本教程以 Unity 3D + VS Code + C# + tolua 为例. 如果你还没有编程基础,建议你先学习一些编程基础.本文不是完全菜鸟教程,主要针对 ...

  4. 无废话WCF入门教程六[一个简单的Demo]

    一.前言 前面的几个章节介绍了很多理论基础,如:什么是WCF.WCF中的A.B.C.WCF的传输模式.本文从零开始和大家一起写一个小的WCF应用程序Demo. 大多框架的学习都是从增.删.改.查开始来 ...

  5. Docker入门教程(四)Docker Registry

    Docker入门教程(四)Docker Registry [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第四篇,介绍了Docker Registry,它 ...

  6. Docker入门教程(二)命令

    Docker入门教程(二)命令 [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第二篇,介绍了Docker的基本命令以及命令的用法和功能. 在Docker ...

  7. node.js Web应用框架Express入门指南

    node.js Web应用框架Express入门指南 作者: 字体:[增加 减小] 类型:转载 时间:2014-05-28 我要评论 这篇文章主要介绍了node.js Web应用框架Express入门 ...

  8. WebGL入门教程(五)-webgl纹理

    前面文章: WebGL入门教程(一)-初识webgl WebGL入门教程(二)-webgl绘制三角形 WebGL入门教程(三)-webgl动画 WebGL入门教程(四)-webgl颜色 这里就需要用到 ...

  9. WebGL入门教程(四)-webgl颜色

    前面文章: WebGL入门教程(一)-初识webgl WebGL入门教程(二)-webgl绘制三角形 WebGL入门教程(三)-webgl动画 颜色效果图: 操作步骤: 1.创建HTML5 canva ...

随机推荐

  1. nginx 反向代理之 proxy_pass

    格式很简单: proxy_pass URL; 其中URL包含:传输协议(http://, https://等).主机名(域名或者IP:PORT).uri. 示例如下: proxy_pass http: ...

  2. HDU - 5952 Counting Cliques

    Counting Cliques HDU - 5952 OJ-ID: hdu-5952 author:Caution_X date of submission:20191110 tags:dfs,gr ...

  3. C# detect latest .net framework installed on PC

    static void GetNetVersionDemo() { using (RegistryKey ndpKey = RegistryKey.OpenBaseKey(RegistryHive.L ...

  4. RCA:收单设备调用云端接口频繁超时排查总结

    研发中心/王鹏 2019年7月 关键词:OKHTTP,安卓,连接复用,开源软件BUG 一.背景知识: OKHTTP已是安卓项目中被广泛使用的网络请求开源库,它有如下特性: 1.支持HTTP/2,允许所 ...

  5. Thymeleaf常用语法:表达式语法之运算符

    Thymeleaf表达式语法之常量分为字符串常量.数字常量.布尔值常量.空值常量:运算符分为算术运算符.关系运算符.条件运算符.无操作符. 开发环境:IntelliJ IDEA 2019.2.2Spr ...

  6. Eclipse的Git插件Egit: merge合并冲突具体解决方法

    http://www.cnblogs.com/wavky/p/3504060.html 稍微总结下弄了半个下午的egit的merge合并冲突解决方法,网上看的都是一个模板出来的,看的糊里糊涂,花了很多 ...

  7. Data Pump Export 数据泵导出因ORA-31693 ORA-02354 和 ORA-01555 错误且没有LOB损坏而失败 (Doc ID 1507116.1)

    Data Pump Export Fails With ORA-31693 ORA-02354 and ORA-01555 Errors And No LOB Corruption (Doc ID 1 ...

  8. Linux使用BIND提供域名解析服务

    DNS(Domain Name System,域名系统)用于管理和解析域名与IP地址对应关系的技术. 主服务器:在特定区域内具有唯一性,负责维护该区域内的域名与IP地址之间的对应关系. 从服务器:从主 ...

  9. Octave中的常用操作2

    >> ones(2:3)ans = 1 1 1 1 1 1 >> 2*ones(2:3)ans = 2 2 2 2 2 2 >> rand(3,3) 产生0~1中的 ...

  10. java8-01-初识Lambda表达式

    为什么用 Lambda表达式          在java8之前  java语言 方法调用  无法将函数作为一个参数      也无法声明返回一个函数          对比 javaScript是典 ...