转自: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. eclipse的一些常用快捷键

    掌握了eclipse快捷键功能,能够大大提高开发效率. 这里总结一些eclipse的常用快捷键. 编辑相关快捷键  1. [ALT+/]:此快捷键为用户编辑的好帮手,能为用户提供内容的辅助,不要为记不 ...

  2. Linux系统:centos7下搭建Rocketmq4.3中间件,配置监控台

    本文源码:GitHub·点这里 || GitEE·点这里 一.环境搭建 环境版本 centos7 jdk1.8 已搭建好 rocketmq4.3 1.下载安装包 网址 https://www.apac ...

  3. abp去掉AbpUser中的Name,Surname,去掉姓和名分离

    abp是国外的框架,默认的框架中的AbpUser表中的Name和Surname是分开的,这不符合国情:可以先去掉 1. 在User类中重写Name和Surname,并设置为私有 2. 在DbConte ...

  4. 使用PrintWriter完成写操作 ,实现简易记事本工具

    package seday07; import java.io.BufferedWriter;import java.io.FileOutputStream;import java.io.IOExce ...

  5. Add a Parametrized Action 添加带参数的按钮

    In this lesson, you will learn how to add a Parametrized Action. These types of Actions are slightly ...

  6. SpringCloud之Eureka:服务发布与调用例子

    Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的. SpringCloud将它集成在其子 ...

  7. Ubuntu16.04 安装 JDK

    1.到Oracle官网下载 地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html ...

  8. Centos7系统Docker安装

    目录 前期说明 安装步骤 1.官网中文安装参考手册 2.确定你是CentOS7及以上版本 3.yum安装gcc相关 4.卸载旧版本 5.安装需要的软件包 6.设置stable镜像仓库 7.更新yum软 ...

  9. jstree级联禁用后代节点的选择框

    用jstree+jquery,做的树形展示. 这个话题,在Stack Overflow上有问答,要获取要禁用的节点,然后用获取子节点方法遍历后代节点,设置禁用选择框. 之后发现,jstree的获取子节 ...

  10. go语言设计模式之Chain Of Responsibility(责任链)

    ChainOfResponsibility.go package ChainOfResponsibility import ( "fmt" "io" " ...