使用 SAP Business Application Studio 创建 Fiori Elements 应用显示 OData 服务的数据
data:image/s3,"s3://crabby-images/bf402/bf4020d8b5d844f3865dc2c3da0a699fca59b279" alt="使用 SAP Business Application Studio 创建 Fiori Elements 应用显示 OData 服务的数据"
关于 SAP Fiori Elements 的介绍,请参考我这些文章:
本文使用公网上可以任意访问的用于教学用途的 northwind OData 服务为例,在 SAP Business Application Studio 上创建一个 Fiori Elements 应用来显示 OData 服务的数据。
这个 OData service 的 url:
https://services.odata.org/V2/Northwind/Northwind.svc/
打开 SAP Business Application Studio,New Project from Template,选择 SAP Fiori Application
:
data:image/s3,"s3://crabby-images/e0908/e0908626880fb68980e26c2b9e52a122184d6cef" alt=""
应用类型选择 SAP Fiori elements
,floorplan 选择 List Report Object Page
:
List Report 标准 SAP Fiori floorplan 之一,它以最常用的表格控件为载体,能够让用户查看大量项目数据。用户可以使用过滤器、排序和分组作为该 floorplan 的开箱即用功能来搜索相关项目。 这些功能都是开箱即用的,无需应用开发人员手动编写 JavaScript 代码。
data:image/s3,"s3://crabby-images/d6c8f/d6c8fb42d6ca0db9642f31417354215e89908a49" alt=""
Data source 选择 Connect to an OData Service
, 将 Northwind OData url 维护进去:
data:image/s3,"s3://crabby-images/1014b/1014bbd81b57eda0154c7d9966dc93ab6ffecbd7" alt=""
Main entity 选择 Customers
,意思是生成的应用里,默认在表格里显示 Customers 数据。
Navigation entity
选择 Orders
:
data:image/s3,"s3://crabby-images/8d387/8d3873c583823c759788ccc503af1142e87c838a" alt=""
随便维护一个 module name,点击 finish:
data:image/s3,"s3://crabby-images/a2446/a2446a2b28a22e7dcfa40083fa598944ef8bbdf8" alt=""
稍等片刻,应用即生成完毕。
右键点击 webapp 文件夹,选择 Preview Application
:
data:image/s3,"s3://crabby-images/aa489/aa4892be23444911d3f729c25e634463f9d4db0d" alt=""
选择 start:
data:image/s3,"s3://crabby-images/f80b2/f80b222e1dbcaeac26cc28b97e02d9683059d48b" alt=""
会自动弹出一个新的浏览器窗口,显示空白数据:
data:image/s3,"s3://crabby-images/e472b/e472b51e3662f7b4ad5b2f4b603a96906cd80541" alt=""
点击齿轮的图标,打开配置页面,将期望查看的 table column 前面的 checkbox 打上勾:
data:image/s3,"s3://crabby-images/7c96a/7c96a46beb825b5381c129747cf684e0a286ed48" alt=""
点击 ok,northwind odata 服务里的客户数据,就显示在这个列表里了:
data:image/s3,"s3://crabby-images/dedfb/dedfb66395c52c00116eef2e26b3ca0b966ffeef" alt=""
但是这种设置下一次本地启动应用后就会丢失。
正规的做法是,对 webapp
文件夹点击右键,选择 Open Guided development
:
data:image/s3,"s3://crabby-images/1d3c9/1d3c918c3fd8002267d59755af4b4406bed8cf11" alt=""
然后选择 Add and edit table columns
,意思是为 List Report 的表格增加新的 column:
data:image/s3,"s3://crabby-images/814d0/814d08e3c23d350df66bc30c4d5cbb323906f88b" alt=""
得到提示是使用 UI.LineItem
注解:
data:image/s3,"s3://crabby-images/0a10d/0a10dd731805a9fa6815eb667ef1afd55372e7bb" alt=""
选中要添加注解的 Entity Type 为 Customer
:
data:image/s3,"s3://crabby-images/4dfb4/4dfb4fb971346cd4eaa373c0456c526f488d566d" alt=""
选择要添加到表格里的列数据源来自 OData 模型的属性 CustomerID
:
data:image/s3,"s3://crabby-images/5f884/5f884513d0cddca36869556ae8127b1d41c519d0" alt=""
自动生成了需要的 annotation,点击 Insert Snippet:
data:image/s3,"s3://crabby-images/973a6/973a6bb334e431c6dce97966a4e053584d2f0a88" alt=""
data:image/s3,"s3://crabby-images/cb34b/cb34b203e20219336198ce01467afcd9f886c383" alt=""
上述代码自动被添加到了 webapp/annotations/annotation.xml:
data:image/s3,"s3://crabby-images/27928/27928b4737ab748764aba17847d71ff708a44514" alt=""
最后刷新应用,发现 CustomerID 能够在默认情况下正常显示了:
data:image/s3,"s3://crabby-images/e9a32/e9a323943e62913bf894e7be1d7c18c39084dbc9" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/e47f625f918f769054ce16c57】。文章转载请联系作者。
评论