当前位置:首页 > 发现 > 其他 > H5 App开发技术如何进行选型 ?

H5 App开发技术如何进行选型 ?

2年前 (2023-08-09)其他344

目前 按照 APP 开发分类,分为以下三大类

原生 APP  [ Android Swift  Flutter  React Native ]WEB APPHybrid App [混合APP  ]

在找工作的当中,很多岗位 要求 会开发 H5 App ,那到底什么是H5 APP 呢?

一开始我也有点疑惑,没接触这块,按自己理解 就是 采用 HTML5 技术开发出的页面应用 跑在移动端当中。

下面引用 阮一峰对 H5 开发解释。

真正理解 H5 开发,需要先搞清楚什么是原生 App、什么是 Web App,因为混合 App 是在它们的基础上诞生的

H5 这个词,可以理解成就是混合 App 模型,只不过它特指混合 App 的前端部分。

因为混合 App 的前端就是 HTML5 网页,所以简称 H5。这个词是国内独有的,基本上都是前端程序员在用,国外不用这个词,就直接叫混合 App。

来对比一下 三种开发模式区别

原生APP

在这里就不讨论原生APP的优点了,想必大家都知道。主要围绕缺点来说

需要 开发 两套 代码 Android  和 IOS旧版本出现bug 无法更新修改,必须用户 下载 更新发版审核时间长,无法随时更新

Web APP

优点

入门简单,成本低 (前端三件套)可以同步更新可以跨平台

缺点

不能直接访问设备硬件和离线存储,功能受限( 相机,蓝牙.......)音视频体验不好

混合APP

优点

开发效率高更新和部署方便,不需要审核,只需要在服务器端部署代码维护方便,版本更新快,成本低

缺点

需要了解 原生开发 才能更好的开发 H5 。需要熟知 原生开发 与 H5 的各种通信和兼容性问题。

什么是 Hybrid App

Hybrid App [ 混合 APP]  指  原生 APP 和 WEB APP 的结合体。它主要是以 JavaScript + Native [ APP 原生] 两者结合相互调用使用。

混合 App 的原生外壳称为"容器",内部隐藏的浏览器,通常使用系统提供的网页渲染控件(即 WebView 控件),也可以自己内置一个浏览器内核。结构上,混合 App 从上到下分成三层:HTML5 网页层、网页引擎层(本质上是一个隔离的浏览器实例)、容器层。

为什么要采用 Hybrid App

Hybrid App  主要是用来优化  原生APP  和 WEB APP 的缺点诞生的新技术,但也有自己的不足。

优点

跨平台

Web 技术是跨平台的,开发者只写一次页面,就能支持多个平台。也就是说,混合 App 只需要一个团队就够了,开发成本较低。

灵活性

混合 App 的灵活性大,很容易集成多种功能。一方面,混合 App 很容易加载外部的 H5 页面,实现 App 的插件结构;另一方面,Web 页面可以方便地调用外部的 Web 服务。

开发方便

Web 页面的调试和构建,远比原生控件简单省时。页面的更新也容易,只要在服务器上发布新版本,触发容器内更新就可以了。另外,Web 开发人员也比较容易招聘,传统的前端程序员可以承担开发任务。

缺点

性能不如 原生 APP , 但相对原生 轻量 。页面跨平台,无法保证多平台统一。需要 前端人员有 原生开发(IOS/Android)  经验,才能完美的上手开发出体验比较好的 混合APP。

什么时候 采用 Hybrid App  应用

对于原生性能要求没那么高企业会根据团队前端技术进行选型......

混合开发任务分配原则

业务关联性强的 H5 做H5 和 原生 都能做的,尽量使用 H5 来做H5 做不了的, 原生 做交互性强的 原生 做 [ 体验佳 ]

原生 与  H5 交互

原生 与  H5 交互主要是采用  JSBridge

它给 JavaScript 提供调用 Native 功能的接口,让混合开发中的前端部分可以方便地使用 Native 的功能(例如:地址位置、摄像头)。JSBridge 的功能不止调用 Native 功能这么简单宽泛。实际上,JSBridge 就像其名称中的Bridge的意义一样,是 Native 和非 Native 之间的桥梁,它的核心是构建 Native 和非 Native 间消息通信的通道,而且这个通信的通道是双向的。

双向通信的通道:

JS 向 Native 发送消息: 调用相关功能、通知 Native 当前 JS 的相关状态等。Native 向 JS 发送消息: 回溯调用结果、消息推送、通知 JS 当前 Native 的状态等。

最后

      相信看到这里的朋友,对于 APP 技术选型 有 大概了解了,每项技术都有优缺点,主要看这项技术是否满足当前项目业务大部分场景,小部分单独优化处理。

相关文章

软件行业被中国原创技术带进了全自动开发时代

软件行业被中国原创技术带进了全自动开发时代

转载于:虎嗅“…它就像是疯狂的技术达尔文实验室。创造它的,是那些永远把手指按在快进键上的研究者。”谁也没有想到,这个威廉·吉布森在1984年写进《神经浪游者》的奇妙隐喻,居然在时隔36年之后,准确命中...

华为大连软件开发云上线,打造软件云生态,加速软件产业升级

华为大连软件开发云上线,打造软件云生态,加速软件产业升级

12月22日,2016华为大连软件开发云上线大会在大连市成功举办,吸引了近千余名政府和软件企业高层、教育行业精英、开发人员、媒体、意见领袖等出席。在本次大会上,华为发布了集华为研发实践、前沿...

自己如何开发软件?

自己如何开发软件?

这是一个非常好的问题,作为一名IT从业者,我来回答一下这个问题。 首先,在当前的信息化时代,很多创业者和职场人都需要一些定制化的小软件,以方...

软件开发如何入门?

软件开发如何入门?

感谢邀请 首先一点,那就是你需要学习很多东西才能成为软件开发人员。 不能详尽说明作为软件开发者你可能需要掌握的所有技...

如何自己搭建一个个人网站?

如何自己搭建一个个人网站?

好家伙,我回顾这些年的程序员生涯,发现折腾最多的是搭建网站。。。 先来秀一下我现在的网站:https://www.cxyxiaowu.com...

做一个网站的成本有多少?网站建设如何报价?告诉你网站开发秘密

做一个网站的成本有多少?网站建设如何报价?告诉你网站开发秘密

如今的互联网时代,任何一个企业或者个人,都离不开互联网,网站是互联网的根本,是外人了解你的企业和个人的窗口,所以建设好你的网站尤为重要。今天给大家解密一下如何建设好你的网站...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。