Jerry曾经写过两篇文章:
- SAP Fiori + Vue = ? - 2018年12月18日
- Fiori Fundamentals和SAP UI5 Web Components - 2019年2月19日
介绍了SAP Fiori是如何一步步走向开放的。在Fiori Fundamentals和SAP UI5 Web Component诞生之前,SAP UI5是开发SAP Fiori应用唯一可供选择的前端框架。
data:image/s3,"s3://crabby-images/e2cec/e2cece38efa490008841094858f8ee5034679c41" alt=""
很显然SAP对前端领域蓬勃发展的Vue,Angular,React这三驾马车并未熟视无睹,这才有了Fiori Fundamentals和SAP UI5 Web Component的问世。
关于这两个名词的区别和联系,请参阅Jerry文首提到的两篇文章,我就不再重复了。
在差不多去年这个时候,SAP社区博客提到,SAP UI5 Web Component发布了Beta版。
data:image/s3,"s3://crabby-images/64a3c/64a3c6b1af5c248ee2589994d8c89f4178eb924c" alt=""
data:image/s3,"s3://crabby-images/64570/64570482bb6e857caebdccb4e80942479b70d5c0" alt=""
那么SAP的工程师们经过了一年的努力后,SAP UI5 Web Component到底有何进展呢?我们一起来看一下。
SAP官方Github上,对UI5 Web Component的定义是:借助它,可以使用自己喜欢的前端框架来开发SAP Fiori应用。
https://github.com/SAP/ui5-webcomponents
data:image/s3,"s3://crabby-images/086c5/086c51de69c35eb88bbe00c999a9e50ec9a777d7" alt=""
因为Jerry之前的文章尝试过Vue,本文就换成用React来演示。
打开UI5 Web Component for React的官网,可以看到所有可用的React Component. React开发人员可以像使用React原生Component完全一致的方式来使用这些SAP包装过的React组件。
https://sap.github.io/ui5-webcomponents-react/?path=/story/welcome-getting-started--page
data:image/s3,"s3://crabby-images/81ebf/81ebf2aeb6cde4ccf950d5c0e870a24a35cb7f88" alt=""
随便浏览一下,能发现SAP提供了丰富的针对React使用的Component库:
data:image/s3,"s3://crabby-images/d7996/d799632c87dab8d91eba308c63d9394bbc4f8aa0" alt=""
选中每个框架,点击Docs,就能看到在React应用里导入这些Component的源代码:
data:image/s3,"s3://crabby-images/1e050/1e0504ab5e9f81077ed37e8551c50e85bf91dd43" alt=""
import { BarChart } from '@ui5/webcomponents-react-charts/lib/BarChart';
这和导入React原生的Component方法没有区别。如此一来,一个掌握了React开发技能的技术人员,几乎不需要任何学习成本,就能迅速上手使用这些SAP提供的Component来开发Fiori应用。所有和User Experience相关的因素,应用开发人员都无需考虑,这一切全部由SAP UI5 Web Component包办了。
说了这么多,还是来动手创建一个Hello World应用吧。
用命令行基于SAP预定义的模板创建一个react应用。React开发的全家桶会自动被该命令创建,给开发人员省去了各种搭建React开发环境的负担。
npx create-react-app my-app --template @ui5/cra-template-webcomponents-react
data:image/s3,"s3://crabby-images/1fe37/1fe374dd127283997d6b3d348867580ed74dac7e" alt=""
接下来就是纯React开发工作了。
创建一个只有一行实现的React Component:
data:image/s3,"s3://crabby-images/358b6/358b6330a7e6be4c2c76ec051b58ac2c51d701c8" alt=""
导入到React应用App.js里:
data:image/s3,"s3://crabby-images/e832f/e832f6fc650c2249513a07d8f948794a05d0fe4b" alt=""
然后npm start,浏览器里就能看到这个React应用的效果了。平平无奇,对吗?
data:image/s3,"s3://crabby-images/0cf4b/0cf4be9fd27b7b001afca6c2b63762d4c7cf53e9" alt=""
那么看看下面这个应用,是不是外观很像SAP Fiori?
data:image/s3,"s3://crabby-images/5b4b8/5b4b848177ed815edeabe848001ce88d5514411f" alt=""
我把该应用的源代码放到了github上,下面只简述要点:
https://github.com/wangzixi-diablo/ui5-for-react
这个应用演示的效果在下面的视频里可以看到:
浏览器里一眼就能发现,这个React页面用到了Line Chart和List两个组件,但实际上这个React应用还演示了不同Component之间的跳转,路由,以及图标的显示等功能,因此导入的组件远远不止Line Chart和List.
下图是从@ui5/webcomponents导入的全部组件列表:
data:image/s3,"s3://crabby-images/94ff5/94ff59d0abcefa642a4bc106e9f0ee95d943365d" alt=""
以LineChart为例,从@ui5/webcomponents导入后,采用React的语法,和我们在UI5原生的XML视图里使用SAP UI5提供的标签一样的方式,在React应用里使用LineChart标签:
data:image/s3,"s3://crabby-images/a4c92/a4c920b1b2ce0075c197cfc91e4288f6f828845b" alt=""
这个LineChart的渲染还是采用HTML5的原生标签canvas实现:
data:image/s3,"s3://crabby-images/f0cea/f0cead6ee2410708c667ad459793139f949ea95e" alt=""
如果对其实现感兴趣,可以到node_modules文件夹下,根据路径@ui5/webcomponents-react-charts找到实现源文件,通过阅读源代码来学习:
data:image/s3,"s3://crabby-images/c9d80/c9d8037453c2e497502caf8d2618efa3af52023a" alt=""
data:image/s3,"s3://crabby-images/c0d75/c0d7583bb5669847d2163df7699d295a99a7239a" alt=""
有了SAP UI5 Web Component,如今在Fiori应用的开发领域里,企业的选择将更加灵活:如果员工前端开发的技术栈还是基于jQuery,那么可以继续使用SAP UI5;如果员工本身就是熟练的React/Angular/Vue开发者,那么SAP UI5 Web Component是一个不错的选择。
data:image/s3,"s3://crabby-images/747ba/747ba18a78cbab2a3c126568b1c1f08bbb872cdb" alt=""
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
data:image/s3,"s3://crabby-images/dbdb5/dbdb58b6e07a167b4c721ac53e4d5857cad20da6" alt=""
网友评论