SPA Fiori开发实战课程(一)

前言

由于工作需要,对Fiori的开发有了一些具体实践,所以做一些记录和总结。

准备工作

1. 对前端有一定的了解,熟悉Node.js,Vue等前端服务器和基础框架。

2. 后端使用ABAP系统。

3. 使用Visual Studio Code进行开发。

工程搭建

打开Visual Studio Code,点击View->Command Palette...,鼠标左键。

 然后Visual Studio Code中间会弹出选择框,输入Fiori:

选择Fiori:Open Application Generator:

会发现有很多模板,可以根据自己需求选择,这里主要是demo,所以选择Basic即可,点击Next:

 

这里要填写正确的url,找ABAP后端要,只有输入了正确的url地址,用户名和密码才能显示出来,输入正确的用户名和密码,点击登录,再点击Next进去下一步。 

给Fiori默认初始化页面一个值,这里使用默认的View1。

 

点击下一步,这里主要是选择项目路径和SAPUI5的版本,这里选择最新版本:

点击Finish完成Demo功能的创建。

这里说下,完成初始化需要一些时间,不要关闭Visual Studio Code,需要等待右下角的依赖安装完成。

启动项目

 在新项目根路径下,执行npm run start命令:

启动后界面:

 这里外面新增一个清单,需要在webapp/view/View1.view.xml修改:

<mvc:View controllerName="project1.controller.View1"xmlns:mvc="sap.ui.core.mvc" displayBlock="true"xmlns="sap.m"><Page id="page" title="{i18n>title}"><content><Listitems="{/ProductCollection}"headerText="Products"><ObjectListItemtitle="{Name}"type="Active"press="onListItemPress"number="{parts:[{path:'Price'},{path:'CurrencyCode'}],type: 'sap.ui.model.type.Currency',formatOptions: {showMeasure: false}}"numberUnit="{CurrencyCode}"><firstStatus><ObjectStatustext="{Status}"state="{path: 'Status',formatter: 'project1.controller.Formatter.status'}" /></firstStatus><ObjectAttribute text="{WeightMeasure} {WeightUnit}" /><ObjectAttribute text="{Width} x {Depth} x {Height} {DimUnit}" /></ObjectListItem></List></content></Page>
</mvc:View>

这里的xml相当于html页面,还需要配置对应的后台逻辑,在webapp/controller/View1.controller.js修改:

sap.ui.define(["sap/ui/core/mvc/Controller",'sap/m/MessageToast','./Formatter','sap/ui/model/json/JSONModel'
],/*** @param {typeof sap.ui.core.mvc.Controller} Controller*/function (Controller, MessageToast, Formatter, JSONModel) {"use strict";return Controller.extend("project1.controller.View1", {onInit: function () {var oModel = new JSONModel({ProductCollection: [{"ProductId": "HT-1000","Category": "Laptops","MainCategory": "Computer Systems","TaxTarifCode": "1","SupplierName": "Very Best Screens","WeightMeasure": 4.2,"WeightUnit": "KG","Description": "Notebook Basic 15 with 2,80 GHz quad core, 15\" LCD, 4 GB DDR3 RAM, 500 GB Hard Disc, Windows 8 Pro","Name": "Notebook Basic 15","DateOfSale": "2017-03-26","ProductPicUrl": "https://sdk.openui5.org/test-resources/sap/ui/documentation/sdk/images/HT-1000.jpg","Status": "Available","Quantity": 10,"UoM": "PC","CurrencyCode": "EUR","Price": 956,"Width": 30,"Depth": 18,"Height": 3,"DimUnit": "cm"},{"ProductId": "HT-1001","Category": "Laptops","MainCategory": "Computer Systems","TaxTarifCode": "1","SupplierName": "Very Best Screens","WeightMeasure": 4.5,"WeightUnit": "KG","Description": "Notebook Basic 17 with 2,80 GHz quad core, 17\" LCD, 4 GB DDR3 RAM, 500 GB Hard Disc, Windows 8 Pro","Name": "Notebook Basic 17","DateOfSale": "2017-04-17","ProductPicUrl": "https://sdk.openui5.org/test-resources/sap/ui/documentation/sdk/images/HT-1001.jpg","Status": "Available","Quantity": 20,"UoM": "PC","CurrencyCode": "EUR","Price": 1249,"Width": 29,"Depth": 17,"Height": 3.1,"DimUnit": "cm"}]});this.getView().setModel(oModel);},onListItemPress: function (oEvent) {MessageToast.show("Pressed : " + oEvent.getSource().getTitle());}});});

 controller文件夹下Formatter.js:

sap.ui.define(function() {"use strict";var Formatter = {status :  function (sStatus) {if (sStatus === "Available") {return "Success";} else if (sStatus === "Out of Stock") {return "Warning";} else if (sStatus === "Discontinued"){return "Error";} else {return "None";}}};return Formatter;},  /* bExport= */ true);

然后前端显示为:

 

结论

以实际ABAP后端为依托,新建了一个Fiori项目,运行、启动,并在首页做了一个简单的List清单,希望对你了解Fiori有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/48024.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于springboot+vue+uniapp的开放实验室预约管理系统

开发语言&#xff1a;Java框架&#xff1a;springbootuniappJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#…

快速创建 vue 项目并添加 Dockerfile 文件

文章目录 快速创建 vue 项目方法 1:使用 Vue CLI方法 2:使用 create-vueVue 前端 Dockerfile 镜像基于 Node 镜像,打包运行基于 Nginx 镜像,直接运行参考🚀 本文内容:使用 Vue CLI / create-vue 快速创建一个 vue 项目,并添加 Dockerfile 镜像实现打包启动。 ⭐ 前提条…

通信流程:https【SSL/TLS】,git仓库【https/SSH】,蓝牙【面对面快传/AirDrop】

目录 HTTPS HTTP&#xff08;80端口&#xff09; SSL/TLS协议&#xff08;传输层&#xff0c;443端口&#xff09; 密文传输&#xff1a;SSL的后续版本TLS TLS1.2握手 1.摘要算法(散列函数 Hash Function)&#xff1a;验证信息的完整性&#xff0c;不可逆 第三方认证 引…

弹性网络回归(Elastic Net Regression)

弹性网络回归&#xff08;Elastic Net Regression&#xff09;的详细理论知识推导 理论背景 弹性网络回归结合了岭回归&#xff08;Ridge Regression&#xff09;和Lasso回归&#xff08;Lasso Regression&#xff09;的优点&#xff0c;通过引入两个正则化参数来实现特征选择…

Day02-Pod资源清单编写,资源的增删改查,镜像的下载策略及常见的Pod相关面试题实战

Day02-Pod资源清单编写&#xff0c;资源的增删改查&#xff0c;镜像的下载策略及常见的Pod相关面试题实战 0、昨日内容回顾&#xff1a;1、K8S资源清单2、实战案例3、K8S的Pod资源运行多个容器案例4、故障排查案例5、环境准备6、故障常用命令7、面试题Q1: 当一个Pod有多个容器时…

【Vue】 组件通信方式

VUE中实现通信的⽅式&#xff1a; props&#xff1a;- 若 父传子&#xff1a;属性值是非函数。- 若 子传父&#xff1a;属性值是函数。emitv-modelrefs- $refs&#xff1a;父→子。$parent&#xff1a;子→父。provide/inject&#xff1a;祖孙组件直接通信&#xff0c;在祖先组…

2024年下半年系统架构师案例预测

2024年上半年系统架构师案例考试题目 第一道大题&#xff1a; 1小问&#xff1a;微服务的概念 2小问&#xff1a;质量属性效用树 3小问&#xff1a;质量评估6要素 第二道题&#xff1a;UML&#xff08;时序图和通信图&#xff09; 1.时序图概念&#xff08;消息的类型有什…

【Android】ConstrainLayout约束布局基本操作

文章目录 介绍约束条件添加方式外边距设置删除方式 添加约束条件父级位置对齐方式基线对齐引导线约束屏障约束 约束偏差使用链控制线性组 介绍 约束布局ConstraintLayout是 Android Studio 2.3 起创建布局后的默认布局 主要是为了解决布局多层嵌套问题&#xff0c;以灵活的方式…

抖音/腾讯/百度ocpm深度回传如何操作?广告投放双出价的投放技巧?

要实现抖音、腾讯和百度的OCPM&#xff08;Optimized Cost Per Mille&#xff09;深度回传&#xff0c;可以通过借助第三方平台&#xff0c;例如&#xff08;转化宝&#xff09;实现广告数据精准回传&#xff0c;如此之外&#xff0c;在广告投放过程中还需要注重这些方面。 转化…

ros笔记02--从零体验ros2中的服务通信方式

ros笔记02--从零体验ros2中的服务通信方式 介绍创建步骤注意事项说明 介绍 在ROS 2中&#xff0c;服务指的是远程过程调用&#xff0c;client调用server&#xff0c;server节点收到数据后计算出结果并返回给client. 服务通常期望能快速返回&#xff0c;因此不应当用于处理长时…

深度学习落地实战:大模型生成图片

前言 大家好&#xff0c;我是机长 本专栏将持续收集整理市场上深度学习的相关项目&#xff0c;旨在为准备从事深度学习工作或相关科研活动的伙伴&#xff0c;储备、提升更多的实际开发经验&#xff0c;每个项目实例都可作为实际开发项目写入简历&#xff0c;且都附带完整的代…

代理伺服器分類詳解

代理伺服器的主要分類 代理伺服器可以根據不同的標準進行分類。以下是幾種常見的分類方式&#xff1a; 按協議分類按匿名性分類按使用場景分類 1. 按協議分類 根據支持的協議類型&#xff0c;代理伺服器可以分為以下幾類&#xff1a; HTTP代理&#xff1a;專門用於處理HTT…

TypeScript 教程(十):项目配置、代码质量与前端框架集成

目录 前言回顾类型声明文件与异步编程1. tsconfig.json 高级配置a. 基本配置b. 高级配置选项 2. 使用 Webpack 构建 TypeScript 项目a. 安装依赖b. 配置 Webpack 3. 使用 Babel 编译 TypeScripta. 安装依赖b. 配置 Babelc. 配置 Webpack 使用 Babel 4. 使用 ESLint 和 TSLinta.…

复杂网络的任意子节点的网络最短距离

复杂网络的任意子节点的网络最短距离 题目要求介绍 本文算法测试用的数据集为空手道俱乐部&#xff0c;其中空手道俱乐部的数据集可通过这个链接进行下载•http://vlado.fmf.uni-lj.si/pub/networks/data/Ucinet/UciData.htm#zachary 摘要 本文旨在解决复杂网络中任意子节点…

Godot学习笔记2——GDScript变量与函数

目录 一、代码编写界面 二、变量 三、函数 四、变量的类型 Godot使用的编程语言是GDS&#xff0c;语法上与python有些类似。 一、代码编写界面 在新建的Godot项目中&#xff0c;点击“创建根节点”中的“其他节点”&#xff0c;选择“Node”。 点击场景界面右上角的绿色…

Spark SQL----GROUP BY子句

Spark SQL----GROUP BY子句 一、描述二、语法三、参数四、例子 一、描述 GROUP BY子句用于根据一组指定的分组表达式对行进行分组&#xff0c;并根据一个或多个指定的聚合函数计算行组上的聚合。Spark还支持高级聚合&#xff0c;通过GROUPING SETS、CUBE、ROLLUP子句对同一输入…

文字溢出隐藏及鼠标悬停显示效果

在本文中&#xff0c;我们将学习如何使用 CSS 和 JavaScript 实现一个简单的文字溢出隐藏效果&#xff0c;当鼠标悬停在文本上时显示完整内容。 创建 HTML 页面结构 首先&#xff0c;我们需要创建一个包含文本内容的 HTML 页面。 <!DOCTYPE html> <html lang"e…

前端Vue组件化实践:自定义发送短信验证码弹框组件

在前端开发中&#xff0c;随着业务逻辑的日益复杂和交互需求的不断增长&#xff0c;传统的整体式开发方式逐渐暴露出效率低下、维护困难等问题。为了解决这些问题&#xff0c;组件化开发成为了一种流行的解决方案。通过组件化&#xff0c;我们可以将复杂的系统拆分成多个独立的…

LeetCode 860柠檬水找零(贪心算法)/406根据身高重建队列(贪心算法)

1. 柠檬水找零 思路分析 只需要维护三种金额的数量&#xff0c;5&#xff0c;10和20。 有如下三种情况&#xff1a; 情况一&#xff1a;账单是5&#xff0c;直接收下。情况二&#xff1a;账单是10&#xff0c;消耗一个5&#xff0c;增加一个10情况三&#xff1a;账单是20&am…

使用Java -jar运行就jar包时报异常:org.yaml.snakeyaml.error.YAMLException异常

Java运行就 .jar包时出现的 YAMLException 异常 我在本地环境测试时&#xff0c;使用 java -jar 命令运行 Java 可执行 .jar 包时&#xff0c;遇到了 org.yaml.snakeyaml.error.YAMLException: java.nio.charset.MalformedInputException: Input length 1 异常&#xff1b;这…