UI5 Tooling是一个基于Node.js开发的开源项目。它提供了一个模块化的、可配置的和可扩展的命令行接口,为应用程序、库和重用组件的高效开发定制了UI5框架。
开源工具重用,灵活扩展,宜集成,先进语言特性,多IDE适用。总之,好用高效。
从架构去了解UI5 Tooling,我的理解是首先它是一组命令行工具,基于NodeJS集成了File System,Project,Logger,Server,Builder这几个模块,不但可以本地执行,还可以用于SAP webIDE以及SAP Business Application Studio,应用的执行可以通过Web浏览器来进行操作。
四种类型的Project:
Node 10以上 + NPM(或者其它依赖 package.json
的package管理器,比如YAML),安装也很简单。
Nodejs官网下载安装,然后执行下面命令既可
npm install --global @ui5/cli
官方文档
安装完成后可以执行ui5 -v
来查看是否安装成功以及看一下版本
以一个简单的例子来说明UI5 Tooling的使用过程。假如我们现在写了一个index.html,并且有相应的js文件和view文件,放在了一个04_copy目录下。
index.html:
<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title>title of 04 copy</title><script id="sap-ui-bootstrap" src=".js" data-sap-ui-theme="sap_fiori_3"data-sap-ui-libs="sap.m" data-sap-ui-compatVersion="edge" data-sap-ui-async="true" data-sap-ui-oninit="module:sap/ui/demo/walkthrough/index"data-sap-ui-resourceroots='{"sap.ui.demo.walkthrough": "./"}'></script>
</head>
<body class="sapUiBody" id="content">
</body>
</html>
index.js
sap.ui.define(["sap/ui/core/mvc/XMLView"
], function (XMLView) {"use strict";ate({viewName: "sap.ui.demo.walkthrough.view.App"}).then(function (oView) {oView.placeAt("content");});
});
l
<mvc:Viewxmlns="sap.m"xmlns:mvc="vc"><Text text="Hello World"/>
</mvc:View>
此时如果直接执行index.html肯定是失败的,F12看报错价位非常看到一个报的是CORS, 一个报的是找不到对应的xml文件,还有Failed to load resource 等等。
解决方案就是我们需要将应用部署到Web server中,UI5 Tooling就是为它而生的。
npm init --yes
自动创建。
其中只有name属性是必需的。
自动创建的内容:
我做这个例子是应用类型,所以正确的结构应该是:
./webapp
./package.json
paackage.json和webapp文件夹同级,webapp中放应用的相关文件
ui5 init
会自动生成一个ui5.yaml文件,这个是UI5 Tooling在这个应用中的配置文件,具体参考:执行后的结构:
./ webapp
./ package.json
./ ui5.yaml
这里metadata中的name属性就是从package.json文件中derive过来的。
此时,如果我们执行ui5 serve
命令的话仍然会报错,缺少manifest.json文件
ui5 serve
即可以启动server,但还是不能正常打开页面,提示找不到jsui5 use sapui5@latest
ui5 add sap.m sap.ui.table themelib_sap_fiori_3
成功后再看yaml文件会发现多了内容:
7. 执行ui5 serve
启动开发服务器
打开浏览器查看
这时再打开index.html是可以正常显示的,我们也可以直接将index.html放布出去,这样就不会再打开文件路径,而是直接打开index.html
使用ui5 build
命令进行编译,它是task centric的一组功能,有下面几种编译模式:
不同的参数会执行不同的task组合,比如默认的是preload形式:会执行下面8个大的task
编译后的文件中会包含一个Component-preload.js
对比下几种模式的区别。
为了能对比出效果,首先将sapui5的runtime下载下来,因为之前用的src是“.js”
如下图resouces文件夹就是从runtime文件中解压出来的文件夹,为了搞清楚src路径的设置特意把runtime解压到了上级目录,resources和workthrough是同级的,workthrough下还有04_copy文件夹,然后才是webapp,index.html在webapp文件夹内
所以src的路径要设置为"../../../resources/sap-ui-core.js"
,这里是一个相对路径,相对谁呢,相对于index.html文件,它上级(webapp)的上级(04_copy)的上级(workthrough)这里才能找到resources文件夹,每一个上级就用../
来表示,这里很重要。
然后再看 ui5 build
和ui5 build --all
能及ui5 build self-contained
的区别。
ui5 build
执行serve dist
查看结果
这时文件加载是会报错
也就是js是没有被编译进去的。
ui5 build --all
这时所需的js文件因为已经编译在其中,所以可以正常显示。
ui5 build self-contained
这种模式会将当前缺少的module以错误的形式暴露出来。
本文发布于:2024-02-02 06:26:40,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170682639941970.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |