当前位置: 首页 > article >正文

SAP学习笔记 - 开发15 - 前端Fiori开发 Boostrap,Controls,MVC(Model,View,Controller),Modules

上一章讲了Fiori开发的准备,以及宇宙至简之HelloWorld。

SAP学习笔记 - 开发14 - 前端Fiori开发 HelloWorld-CSDN博客

本章继续学习 Fiori 开发的知识:

Bootstrap,Controls,MVC(Model,View,Controller),Modules的概念。

目录

1,Boostrap

1-1,先改/加几个文件

1-2,简单说一下几个属性

2,Control(控件)

1),index.html

2),index.js

3,XML View

1),App.view.xml

2),index.js

4,Controllers

1),App.view.xml

2),App.controller.js

5,Modules

1),App.controller.js

6,JSON Model

1),App.Controller.js

2),App.view.xml


下面是详细内容。

1,Boostrap

 OpenUI5 SDK - Demo Kit

所谓的Bootstrap,就是加载,引导。

你要用OpenUI5,那你咋用呢?你得加载UI5的包(就是一个js文件),然后才能用里面的功能。

1-1,先改/加几个文件

1),index.html

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>UI5 Walkthrough</title><scriptid="sap-ui-bootstrap"src="resources/sap-ui-core.js"data-sap-ui-theme="sap_horizon"data-sap-ui-libs="sap.m"data-sap-ui-compat-version="edge"data-sap-ui-async="true"data-sap-ui-on-init="module:ui5/walkthrough/index"data-sap-ui-resource-roots='{"ui5.walkthrough": "./"}'></script>
</head>
<body>
<div>Hello World</div>
</body>
</html>

 把上一章学习用的VSCode打开,然后把 index.html 替换成上面的内容

2),index.js

加完文件默认就给写了个框架,这个还比较好哈

先按官网写成下面这样看看效果 

sap.ui.define([], () => {"use strict";alert("UI5 is ready");
});

 

然后 用 ui5 serve 启动。跑出来是这样的

然后按下 F12 键,发现咋出错了呢?

官方文档有点儿挫哈,其实这里就是它先假定你已经把SAP UI5的js给下载到本地了,咱还没下呢

或者你可以这么理解,官网上面的代码,其相对路径是基于它自己网址的,比如下面是完整路径

https://openui5.hana.ondemand.com/resources/sap-ui-core.js

我们可以下载下来,然后放到本地,作为我们自己的相对路径,

或者你直接写上面那个完整路径也OK

我这里改成完整路径:https://openui5.hana.ondemand.com/resources/sap-ui-core.js

这样再跑一下,就能加载了

1-2,简单说一下几个属性

- src="resources/sap-ui-core.js"
  这个上面已经说了,就是指向UI5 js文件的路径。现实项目一般都会指向本地js文件

- data-sap-ui-theme="sap_horizon"
  这个就是css样式主题
  
- data-sap-ui-libs="sap.m"
  这个就是使用的库,sap.m 是 SAP Fiori 应用的标准移动控件库,比如button,text...

- data-sap-ui-compat-version="edge"
  这个表示使用的是最新稳定版本,可能不包含向后兼容的过时版本内容

- data-sap-ui-async="true"
  这个表示适用异步

- data-sap-ui-on-init="module:ui5/walkthrough/index"
  这个就相当于加个包名

- data-sap-ui-resource-roots='{
    "ui5.walkthrough": "./"
  }'>
  这个东西有点儿意思,和上面那个配套,就是该包 ui5/walkthrough 实际指向的是当前文件的所属文件夹

上面用的是sap.m库,这里再说几个常用的库:

库名用途
sap.m移动端控件 (Fiori 标准)
sap.fFlexible Column Layout 等布局
sap.ui.table高级表格控件
sap.tnt工具类控件 (SideNavigation 等)

上面写了那个data-sap-ui-libs 之后,运行的时候,浏览器会下载这么一大堆内容:

(实际项目当中,应该也会把这些拿过去放本地吧,这个我也不太确定)

2,Control(控件)

也是需要先改几个文件:

1),index.html

跟上面差不多,就是加个body 标签

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>UI5 Walkthrough</title><scriptid="sap-ui-bootstrap"src="https://openui5.hana.ondemand.com/resources/sap-ui-core.js"data-sap-ui-theme="sap_horizon"data-sap-ui-libs="sap.m"data-sap-ui-compat-version="edge"data-sap-ui-async="true"data-sap-ui-on-init="module:ui5/walkthrough/index"data-sap-ui-resource-roots='{"ui5.walkthrough": "./"}'></script>
</head>
<body class="sapUiBody" id="content">Hello, this is body's contents.
</body>
</html>

2),index.js

这里用的是 sap/m 库下面的Text 控件

sap.ui.define(["sap/m/Text"
], (Text) => {"use strict";new Text({text: "This is sap/m/Text Control - Hello World"}).placeAt("content");
});

跑一下看看结果

下面这个是index.html 文件里面写的文本再加上sap/m/Text组件里面 placeAt 函数加到后面的。

- Hello, this is body's contents. This is sap/m/Text Control - Hello World

3,XML View

OpenUI5 SDK - Demo Kit

上面显示网页内容的时候,是在index.js 里面直接用 Control,比如 new Text 这种来实现。

那要是这么用的话,实际画面一般都很复杂,不太好画。

SAP提供了XML View这种方式来方便的渲染前端。

1),App.view.xml

新建App.view.xml之后,也是生成了默认的代码:

咱们也是修改一下先:

<mvc:Viewxmlns="sap.m"xmlns:mvc="sap.ui.core.mvc"><Text text="Hello World in mvc:View"/>
</mvc:View>

视图创建好以后该怎么加载呢?就用index.js来控制加载。

2),index.js

sap.ui.define(["sap/ui/core/mvc/XMLView"
], (XMLView) => {"use strict";XMLView.create({viewName: "ui5.walkthrough.view.App"}).then((oView) => oView.placeAt("content"));
});

 说明一下这里的几行关键代码:

- "sap/ui/core/mvc/XMLView"

  引入XMLView 模块

- viewName: "ui5.walkthrough.view.App"

  这里就是指向 ui5.walkthrough (真实路径是在index.html 里面定义的)里面的view,

  也就是 App.view.xml

- then((oView) => oView.placeAt("content"));

  处理异步结果,使浏览器不会卡在这里,而是继续往下跑,等这里加载OK了再执行then里的代码

这样就加载了App.view.xml 视图了

这个视图的用途,就如其名,是为了写视图专用的

index.js 是该视图的控制器,用于控制加载哪个视图等等。

上面说了View(视图),以及控制使用哪个视图的index.js,那么视图里面的按钮等事件是怎么控制的呢?就需要Controllers(控制器)。 

4,Controllers

OpenUI5 SDK - Demo Kit

1),App.view.xml

<mvc:ViewcontrollerName="ui5.walkthrough.controller.App"xmlns="sap.m"xmlns:mvc="sap.ui.core.mvc"><Buttontext="Say Hello"press=".onShowHello"/>
</mvc:View>

说一下几行关键代码:

- controllerName="ui5.walkthrough.controller.App"

关联该View所对应的控制器,这里指的是 controller文件夹下的App.controller.js文件

- xmlns:mvc="sap.ui.core.mvc">

  xmlns 指向的是命名空间,应该就是包名

- press=".onShowHello"/>

press 指的是按下,Web HTML里面叫click,但是移动设备也没法click,press比较贴切

.onShowHello,「.」(点号)指的是本控制器,即与view同名(比如这里是App)的控制器

2),App.controller.js

默认也是生成了大框

先修改一下成下面这样 

sap.ui.define(["sap/ui/core/mvc/Controller"
], (Controller) => {"use strict";return Controller.extend("ui5.walkthrough.controller.App", {onShowHello() {// show a native JavaScript alertalert("Hello World in mvc/Controller");}});
});

说明一下几行关键代码:

- "sap/ui/core/mvc/Controller"

这个跟 include 差不多,引入基类

- ], (Controller) => {

  将引入的基类作为参数传入

- Controller.extend("ui5.walkthrough.controller.App", {

  继承基类,在此基础上加功能,这里就是加 onShowHello函数

贴张图展示上面的View,Controller之间的关系:等以后Model再加上,mvc就全乎了

跑一下看看,就是画面上有个Say Hello 按钮,点了之后,就出来一个Message

5,Modules

OpenUI5 SDK - Demo Kit

注意这个还不是mvc中的m,这里就指的是模块儿,具体介绍一个MessageToast模块儿。

我合计SAP是不是搞模块搞上瘾了。

咱们来看一下这个模块是个啥东西。

1),App.controller.js

sap.ui.define(["sap/ui/core/mvc/Controller","sap/m/MessageToast"
], (Controller, MessageToast) => {"use strict";return Controller.extend("ui5.walkthrough.controller.App", {onShowHello() {MessageToast.show("Hello World from Controller");}});
});

来说明一下几行关键代码:

- "sap/m/MessageToast"

  导入MessageToast工具(这个就叫模块儿),不导入它你就用不了它,用Include/Import导进来

- ], (Controller, MessageToast) => {

  这个东西本身叫回调函数,参数就是传入或者叫注入Include的模块儿

  这里想说明一下异步的问题:只有当这些模块都加载完之后,前端才会开始执行回调

- MessageToast.show("Hello World from Controller");

  加载完Module(模块)之后,进入到回调函数里面,就可以用导入的模块啦

效果就弹出来这么一个toast message

之前用alert 弹出来的,框框丑丑的,这种toast message比较漂亮

不管它过一阵子它自己就会自动消失,你点一下它就马上消失

6,JSON Model

OpenUI5 SDK - Demo Kit

上面那个Module不是mvc中的m,那mvc中的m 是啥呢?这不就来了,就是这个JSON Model。

1),App.Controller.js

sap.ui.define(["sap/ui/core/mvc/Controller","sap/m/MessageToast","sap/ui/model/json/JSONModel"
], (Controller, MessageToast, JSONModel) => {"use strict";return Controller.extend("ui5.walkthrough.controller.App", {onInit() {// set data model on viewconst oData = {recipient : {name : "World in oData"}};const oModel = new JSONModel(oData);this.getView().setModel(oModel);},onShowHello() {MessageToast.show("Hello World from button");}});
});

下面来看看几行代码的含义:

-   "sap/ui/model/json/JSONModel"
- ], (Controller, MessageToast, JSONModel) => {

 上面两句代码的意思是Include/Import JSONModel基类,然后将该类传入回调函数 

- 下面这一段的意思是

  - 定义一个名叫 recipient 的 oData变量(本质是Json字符串),正式项目里面,会从DB取值

  - 然后把该变量给塞到JSONModel对象里面,赋值给oModel变量(常量)

  - 用this.getView函数取得该Controller的同名View,即 App.view.xml

  - 再用setModel 把 oModel变量赋值给该View

         const oData = {
            recipient : {
               name : "World in oData"
            }
         };
         const oModel = new JSONModel(oData);
         this.getView().setModel(oModel);

2),App.view.xml

<mvc:ViewcontrollerName="ui5.walkthrough.controller.App"xmlns="sap.m"xmlns:mvc="sap.ui.core.mvc"><Buttontext="Say Hello"press=".onShowHello"/><Inputvalue="{/recipient/name}"description="Hello {/recipient/name} from View"valueLiveUpdate="true"width="60%"/>
</mvc:View>

看一下下面几句代码:

-  <Input

      value="{/recipient/name}"   =》这句是属于简单取值,对应的是Controler里面的Jason的名值对

      description="Hello {/recipient/name}" =》这句是属于复杂取值,和Hello字符串 掺杂在一起

      valueLiveUpdate="true"  =》value的即时更新,和Jason无关,value值变了,Des也会跟着变

      width="60%"/>

跑一下看看

value值变为 Fiori World,Description 值会自动变为 Hello + Fiori World

画张图展示一下包括上面mvc 的整体Image:

以上就是本篇的全部内容。

更多SAP顾问业务知识请点击下面目录链接或东京老树根的博客主页

https://blog.csdn.net/shi_ly/category_12216766.html

东京老树根-CSDN博客

相关文章:

SAP学习笔记 - 开发15 - 前端Fiori开发 Boostrap,Controls,MVC(Model,View,Controller),Modules

上一章讲了Fiori开发的准备&#xff0c;以及宇宙至简之HelloWorld。 SAP学习笔记 - 开发14 - 前端Fiori开发 HelloWorld-CSDN博客 本章继续学习 Fiori 开发的知识&#xff1a; Bootstrap&#xff0c;Controls&#xff0c;MVC(Model&#xff0c;View&#xff0c;Controller&a…...

Redis中的过期策略与内存淘汰策略

因为Redis是纯内存操作&#xff0c;所以在Redis中创建的键一般都会带有过期时间&#xff0c;以此来保证内存中存储数据的时效性。这篇文章我们就来讲解一下Redis中的过期策略与内存淘汰策略。 如何设置Redis中键的过期时间&#xff1f; Redis提供了4个命令来设置键的过期时间&…...

基于SDN环境下的DDoS异常攻击的检测与缓解

参考以下两篇博客&#xff0c;最后成功&#xff1a; 基于SDN的DDoS攻击检测和防御方法_基于sdn的ddos攻击检测与防御-CSDN博客 利用mininet模拟SDN架构并进行DDoS攻击与防御模拟&#xff08;Ryumininetsflowpostman&#xff09;_mininet模拟dos攻击-CSDN博客 需求 H2 模拟f…...

HarmonyOS 实战:给笔记应用加防截图水印

最近在做笔记类应用时&#xff0c;遇到一个头疼的需求&#xff1a;防止用户内容被非法截图传播。思来想去&#xff0c;加水印是个直接有效的方案。研究了 HarmonyOS 的开发文档后&#xff0c;发现用 Canvas 配合布局组件能轻松实现动态水印效果。今天就来聊聊如何给笔记页面加上…...

如何轻松地将文件从 PC 传输到 iPhone?

传统上&#xff0c;您可以使用 iTunes 将文件从 PC 传输到 iPhone&#xff0c;但现在&#xff0c;使用 iTunes 已不再是唯一的选择。现在有多种不同且有效的方法可以帮助您传输文件。在今天的指南中&#xff0c;您可以找到 8 种使用或不使用 iTunes 传输文件的方法&#xff0c;…...

前端面试二之运算符与表达式

目录 1.JavaScript 中的 和 运算符 2.|| (逻辑或) 运算符 与 ES6 默认参数的区别 与 ?? (空值合并运算符) 的区别 3.?.&#xff08;可选链&#xff09;运算符 (1). 安全访问深层嵌套属性 (2). 安全调用可能不存在的函数 (3). 安全访问数组元素 4.展开运算符 (..…...

【运维实战】使用Nvm配置多Node.js环境!

背景 新项目 使用Node.js-v16.17.1旧项目 使用Node.js- v14.18.0 【且依赖于node-saas模块&#xff0c;根据 node-sass 的官方文档&#xff0c;目前最新版本的 node-sass&#xff08;即 v5.0.0&#xff09;支持的 Node.js 版本范围是 Node.js 10.x、Node.js 12.x、Node.js 14.…...

Bresenham算法

一 Bresenham 绘直线 使用 Bresenham 算法&#xff0c;可以在显示器上绘制一直线段。该算法主要思想如下&#xff1a; 1 给出直线段上两个端点 &#xff0c;根据端点求出直线在X,Y方向上变化速率 &#xff1b; 2 当 时&#xff0c;X 方向上变化速率快于 Y 方向上变化速率&am…...

【从GEO数据库批量下载数据】

从GEO数据库批量下载数据 1&#xff1a;进入GEO DataSets拿到所需要下载的数据的srr.list&#xff0c;上传到linux&#xff0c; 就可以使用prefetch这个函数来下载 2&#xff1a;操作步骤如下&#xff1a; conda 安装sra-tools conda create -n sra-env -c bioconda -c co…...

day 44

使用DenseNet预训练模型对cifar10数据集进行训练 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms, models from torch.utils.data import DataLoader import matplotlib.pyplot as plt import os# 设置中文字体…...

鸿蒙OSUniApp开发跨平台AR扫描识别应用:HarmonyOS实践指南#三方框架 #Uniapp

UniApp开发跨平台AR扫描识别应用&#xff1a;HarmonyOS实践指南 前言 随着增强现实&#xff08;AR&#xff09;技术在移动应用中的广泛应用&#xff0c;越来越多的开发者需要在跨平台应用中实现AR功能。本文将深入探讨如何使用UniApp框架开发一个高性能的AR扫描识别应用&…...

NER实践总结,记录一下自己实践遇到的各种问题。

更。 没卡&#xff0c;跑个模型休息好几天&#xff0c;又闲又急。 一开始直接套用了别人的代码进行实体识别&#xff0c;结果很差&#xff0c;原因是他的词表没有我需要的东西&#xff0c;我是用的医学文本。代码直接在github找了改的&#xff0c;用的是BERT的Chinese版本。 然…...

微信小程序实现运动能耗计算

微信小程序实现运动能耗计算 近我做了一个挺有意思的微信小程序&#xff0c;能够实现运动能耗的计算。只需要输入性别、年龄、体重、运动时长和运动类型这些信息&#xff0c;就能算出对应的消耗热量。 具体来说&#xff0c;在小程序里&#xff0c;性别不同&#xff0c;身体基…...

iTunes 无法备份 iPhone:10 种解决方法

Apple 设备是移动设备市场上最先进的产品之一&#xff0c;但有些人遇到过 iTunes 因出现错误而无法备份 iPhone 的情况。iTunes 拒绝备份 iPhone 时&#xff0c;可能会令人非常沮丧。不过&#xff0c;幸运的是&#xff0c;我们有 10 种有效的方法可以解决这个问题。您可以按照以…...

施耐德特价型号伺服电机VIA0703D31A1022、常见故障

⚙️ ‌一、启动类故障‌ ‌电机无法启动‌ ‌可能原因‌&#xff1a;电源未接通、制动器未释放、接线错误或控制器故障。‌解决措施‌&#xff1a; 检查电源线路及断路器状态&#xff1b;验证制动器是否打开&#xff08;带制动器型号&#xff09;&#xff1b;核对电机与控制器…...

LangChain4J 使用实践

这里写目录标题 大模型应用场景&#xff1a;创建一个测试示例AIService聊天记忆实现简单实现聊天记录记忆MessageWindowChatMemory实现聊天记忆 隔离聊天记忆聊天记忆持久化 添加AI提示词 大模型应用场景&#xff1a; 创建一个测试示例 导入依赖 <dependency><groupI…...

慢SQL调优(二):大表查询

最近在工作中写SQL出现几次慢SQL的BUG&#xff0c;总结下来归根到底就是因为大表的原因~这表有多大呢&#xff0c;执行 select COUNT(1) FROM position 是出不来结果滴&#xff0c;每天保底新增1000条数据&#xff0c;可想而知有多大了&#xff0c;所以多次踩坑了这张表。所以…...

【C++】—— 从零开始封装 Map 与 Set:实现与优化

人生的态度是&#xff0c;抱最大的希望&#xff0c;尽最大的努力&#xff0c;做最坏的打算。 —— 柏拉图 《理想国》 目录 1、理论基石——深度剖析 BSTree、AVLTree 与 RBTree 的概念区别 2、迭代器机制——RBTree 迭代器的架构与工程实现 3、高级容器设计——Map 与 Set…...

内网穿透之Linux版客户端安装(神卓互联)

选择Linux系统版本 获取安装包 &#xff1a;https://www.shenzhuohl.com/download.html 这里以Ubuntu 18.04为例&#xff0c;其它版本方法类似 登录Ubuntu操作系统&#xff1a; 打开Ubuntu系统终端&#xff0c;更新版本 apt-get update 安装运行环境&#xff1a; 安装C 运…...

开疆智能Profinet转Profibus网关连接CMDF5-8ADe分布式IO配置案例

本案例是客户通过开疆智能研发的Profinet转Profibus网关将PLC的Profinet协议数据转换成IO使用的Profibus协议&#xff0c;操作步骤如下。 配置过程&#xff1a; Profinet一侧设置 1. 打开西门子组态软件进行组态&#xff0c;导入网关在Profinet一侧的GSD文件。 2. 新建项目并…...

华为云Flexus+DeepSeek征文|Flexus云服务器单机部署+CCE容器高可用部署快速搭建生产级的生成式AI应用

前引&#xff1a; 在AI技术高速演进的浪潮中&#xff0c;如何快速、高效、安全地搭建一个大模型应用平台&#xff0c;成为开发者和企业关注的焦点。近日&#xff0c;华为云推出的Flexus云服务器配合CCE容器引擎和Dify LLM应用开发平台&#xff0c;带来了极具吸引力的解决方案。…...

扫地机产品--材质传感器算法开发与虚拟示波器

扫地机产品–材质传感器算法开发与虚拟示波器 文章目录 扫地机产品--材质传感器算法开发与虚拟示波器**一、材质传感器的工作原理**二、核心功能与应用场景三、技术参数与产品示例四.MCU 与压电陶瓷超声波的材质检测技术方案实现原理分析4.1 超声波原理4.2表面类型检测4.3 超声…...

[蓝桥杯]上三角方阵

上三角方阵 题目描述 方阵的主对角线之上称为"上三角"。 请你设计一个用于填充 nn 阶方阵的上三角区域的程序。填充的规则是&#xff1a;使用 1&#xff0c;2&#xff0c;3.... 的自然数列&#xff0c;从左上角开始&#xff0c;按照顺时针方向螺旋填充。 例如&am…...

60天python训练计划----day44

DAY 44 预训练模型 知识点回顾&#xff1a; 预训练的概念常见的分类预训练模型图像预训练模型的发展史预训练的策略预训练代码实战&#xff1a;resnet18 一、预训练的概念 我们之前在训练中发现&#xff0c;准确率最开始随着epoch的增加而增加。随着循环的更新&#xff0c;参数…...

【JAVA版】意象CRM客户关系管理系统+uniapp全开源

一.介绍 CRM意象客户关系管理系统&#xff0c;是一个综合性的客户管理平台&#xff0c;旨在帮助企业高效地管理客户信息、商机、合同以及员工业绩。系统通过首页、系统管理、工作流程、审批中心、线索管理、客户管理、商机管理、合同管理、CRM系统、数据统计和系统配置等模块&…...

API异常信息如何实时发送到钉钉

#背景 对于一些重要的API&#xff0c;开发人员会非常关注API有没有报错&#xff0c;为了方便开发人员第一时间获取错误信息&#xff0c;我们可以使用插件来将API报错实时发送到钉钉群。 接下来我们就来实操如何实现 #准备工作 #创建钉钉群 如果已有钉钉群&#xff0c;可以跳…...

Python爬虫(48)基于Scrapy-Redis与深度强化学习的智能分布式爬虫架构设计与实践

目录 一、背景与行业痛点二、核心技术架构设计2.1 分布式爬虫基础架构2.2 深度强化学习模块 三、生产环境实践案例3.1 电商价格监控系统3.2 学术文献采集系统 四、高级优化技术4.1 联邦学习增强4.2 神经架构搜索&#xff08;NAS&#xff09; 五、总结&#x1f308;Python爬虫相…...

AtCoder Beginner Contest 407 E - Most Valuable Parentheses

AtCoder Beginner Contest 407 E - Most Valuable Parentheses E - Most Valuable Parentheses 反悔贪心算法 性质&#xff1a; 假设长度为 n n n&#xff0c; n ≡ 0 ( m o d 2 ) n \equiv 0 \pmod{2} n≡0(mod2) 的括号序列是合法的&#xff0c;那么有 n 2 \frac{n}{2}…...

(1-6-3)Java 多线程

目录 0.知识拓扑 1. 多线程相关概念 1.1 进程 1.2 线程 1.3 java 中的进程 与 线程概述 1.4 CPU、进程 与 线程的关系 2.多线程的创建方式 2.1 继承Thread类 2.2 实现Runnable接口 2.3 实现Callable接口 2.4 三种创建方式对比 3.线程同步 3.1 线程同步机制概述 …...

java31

1.网络编程 三要素&#xff1a; 网址实质上就是ip InetAddress: UDP通信程序&#xff1a; 多个接收端的地址都要加入同一个组播地址&#xff0c;这样发送端发信息&#xff0c;全部接收端都能接受到数据 广播的代码差不多&#xff0c;就是地址不一样而已 TCP通信程序&#xf…...