HTML5到跨平台App应用深度解析

本文将进一步介绍跨平台技术的分类,并深度揭示APICloud混合开发技术的技术原理。编程

跨平台技术的分类小程序

目前跨平台技术领域分为两个发展方向:架构

第一个是HTML5 + Native混合方向;app

第二个是中间语言编译方向,其中APICloud和小程序都属于前者。编程语言

HTML5 + Native混合,也就是咱们一般所说的混合开发。布局

这种模式的开发主体是HTML5,但整个app的架构是Native架构:经过HTML5快速实现app的UI布局、产品业务逻辑,在开发过程当中涉及HTML5没法实现或者体验很差的功能,则借助Native模块来实现。性能

混合开发在保证app渲染效率和用户体验的同时,可以下降app开发成本和复杂度,提升app开发效率。学习

中间语言编译方向,表明产品为React Native(RN),Xamarin以及Google刚刚发布的Flutter。编码

如何理解中间语言编译?翻译

以RN为例,传统的app开发,要求开发者使用Android和iOS原生技术-Java、Object-C、C/C++等进行开发,而RN的开发过程则要求开发者使用JS进行编码输出app,但在app执行过程当中,JS又映射回到安卓和iOS原生层面执行。借助JS快速实现编码,翻译为原生代码执行,这就是中间语言编译方向。

Xamarin则要求使用微软本身的语言C#,对于大部分开发者而言,C#的学习成本比较高且Xamarin须要付费使用,所以它目前在国内应用比较少。Flutter的开发语言为Dart,它是谷歌发明的编程语言,这个语言颇有趣,它的语法相似于C语言,又将JS和Java的一些设计思想以及语法规则融合了进去。Dart语言在此前应用比较少,可参考的资料很少,开发者上手须要一个过程。

Html5到跨平台app应用

每一项新兴技术的出现和流行,都是为了规模化的去统一解决一系列复杂问题,APICloud选择混合开发方向,目的是但愿借助HTML5下降app开发复杂度,提升app开发效率。

经过工程化的实践手段,咱们首先设计了一个app开发引擎。简单的向你们介绍一下这个引擎的架构:

整个引擎基于Android和iOS系统的原生技术架构

最上层为app应用层,涉及到业务以及功能相关的部分,要求开发者使用HTML + CSS进行UI布局和渲染,功能和业务逻辑则经过JS实现,这是app开发者直接参与的地方。

第二层则是API层,API层核心的功能是桥接和管理,负责JS与Java,JS与Object-C之间的通信,管理API的分发,以及一些JS-Framework的加载和执行。

引擎与模块的API经过这里向开发者开放

接下来是引擎,引擎主要负责应用的消息命令管理、事件管理、模块管理、以及UI渲染。

咱们经过将Android和iOS系统的原生窗口机制抽象出来,再模拟原生的方式实现了一个新的窗口系统,由Widget/Window/Frame/UI Model构成,造成混合渲染能力,使得app性能和体验接近原生。

引擎经过开放模块机制,支持动态载入模块,丰富和加强app功能,知足各式各样的需求。

最底下则是OS层,OS层中主要涉及Android和iOS系统之间一些不一样的特性,是咱们要花大量时间精力进行适配和抽象的地方。

除此以外,一个app还应当具有符合Android和iOS原生app的生命周期特性,例如:如何启动,启动流程以及生命周期事件分发等。

如下是app开发引擎对app生命周期管理的主要处理流程。

引擎触发app的生命周期同原生app一致,触发点来自用户

用户点击桌面的某个图标,或者点击手机状态栏的某个通知,系统会将这个事件分发到对应的app,引擎在收到这个事件后开始初始化。

初始化的过程为:原生窗口系统初始化,展现启动页->HTML5运行环境初始化->加载模块运行环境->事件及消息队列管理初始化->根窗口开始渲染,以后开始加载HTML5页面,这个HTML5页面是整个app的入口。

App启动完毕后进入等待状态,由用户的点击等事件驱动打开新的窗口,加载新的模块,UI更新等。

经过app开发引擎,初步达到了使用HTML5 + Native混合开发,提升开发效率的目的,然而实践过程远比想象的要复杂,为此APICloud在专产品层面付出了非凡的努力。

在浩瀚的人类文明中,得益于计算机的迅速发展和技术的普遍应用,拉开了第三次工业革命的新篇章,与此同时信息技术成为拉动经济的重要增加点。

在移动互联网时代,app开发技术无疑是行业发展的重要驱动力,企业对于产品快速落地与灵活迭代的迫切需求,则使跨平台开发技术普遍应用;而APICloud经过拥有核心知识产权的混合app开发技术,进一步帮助企业快速实现移动互联网布局,并以生态之力为开发者提供全面的技术服务。

相关文章
相关标签/搜索