来自Jerry的同事,Yang Joey。javascript
相信大部分C4C的UI developer包括我刚开始的时候都会比较好奇咱们平时写的javascript代码是如何运行在移动设备上的,一样的,我也对这个问题十分感兴趣。因而,以安卓为例子,我把咱们发布到安卓应用市场的app解压出来研究了一下。html
上图是一个cordova的整体框架的描述,能够看到cordova主要由两部分构成。 第一部分:Cordova Application是Cordova框架独立于不一样手机操做系统的一个封装层。具体包括 1)Web app(包括具体的app的HTML/JS/CSS代码等); 2)Cordova框架已经封装好的核心插件(如相机、存储等系统调用),这块是Cordova的核心部分。固然,开发者也能够基于它的插件体系,扩展出新的插件; 第二部分:Mobile OS就是具体的手机操做系统层了,Cordova目前支持大部分的手机OS:ios、android、wp、blackberry等等java
第二部分咱们在这里就不赘述,都是mobile OS的各类原生功能。android
那么咱们先来看第一部分的webapp这一部分,咱们将下载下来的apk文件解压缩,以下所示是一个很经典的安卓app的apk包的结构:ios
上文中讲过, 用Cordova工具将C4C Aurora的项目文件打包成Android或者iOS原生应用后,以Android平台为例,客户安装apk在安卓设备上后,运行在安卓手机上的C4C应用实际运行在WebView中。 WebView里加载的JavaScript和HTML文件实际上已经保存在了Cordova构建出来的项目包(即apk文件)里。在运行时,这些资源文件经过Embedded server加载到WebView里。 固然,手机C4C应用上全部须要显示的Transaction数据,好比在手机C4C应用上打开Account工做中心,看到的全部Account数据都来自对应的C4C tenant,这些数据的读取请求经过embedded Server发送到C4C tenant的后台 ABAP系统上去。web
Jerry在博客(https://blogs.sap.com/2017/08/17/step-by-step-to-package-a-fiori-application-into-your-android-device-using-cordova/)中有写到如何用cordova建立一个fiori 风格app, 文中有讲到咱们在开发这样一个app的时候会有一个默认的index.js生成,咱们基于这个文件为入口进行开发cordova的应用,咱们在assets->www下面找到了这个index.js文件,同时咱们看到了几个zip包,这几个zip分别来自咱们C4C开发组所开发的oberon和lead cod,里面包含了咱们开发的javascript代码和样式表文件,这些文件便是上文提到的保存在cordova构建出来的项目包里的代码和html文件。app
咱们打开一个oberon.zip看一看里面的内容,好比我如今打开的是咱们开发的RUI client下面的全部javascript代码和样式表文件的目录,library-preload.js就是咱们开发的javascript代码压缩以后的合集,其中也包括一些咱们会用到的UI5的类库。框架
经过jerry的博客咱们得知应用运行时会先加载这个js文件,那么打开这个文件看一下上文提到的oberon.zip等zip里面的代码是如何被加载和运行的。webapp
能够看到这里加载了两个js文件,运行了一个app.initialize()方法. 这个方法被定义在加载的第二个js文件js/index.js里面,打开这个index.js文件以后发现的确是这里的initialize 方法加载了sap的UI标准库,主题库,语言等。工具
上文中讲了第一部分中的webapp,那么咱们来看看开发者本身开发的插件这一部分,在Jerry的博客中有写到如何用java开发一个自定义的cordova插件:https://blogs.sap.com/2017/08/18/step-by-step-to-create-a-custom-cordova-plugin-for-android-and-consume-it-in-your-ui5-application/,文中有提到咱们如何在UI5的application中去调用咱们开发的cordova插件,咱们在这个解压出来的包里面也能够看到这些去消费插件的这些js class:
打开一个调用名片扫描插件的文件夹,咱们发现与开发的时候文件目录基本一致, <project folder>/platforms/android/assets/
要获取更多Jerry的原创文章,请关注公众号"汪子熙":