• 技术文章 >web前端 >H5教程

    HTML5plus移动应用的开发实例分享

    小云云小云云2018-02-08 15:23:13原创1929
    什么是 HTML5plusDCloud 公司提供的,使用传统 web 技术开发移动应用的解决方案。本文主要和大家分享HTML5plus移动应用的开发实例分享,希望能帮助到大家。

    增强版的手机浏览器引擎,让HTML5达到原生水平!

    产品口号,总会有些夸张的成分,不要在意这些细节。

    Tips

    使用方式

    Runtime

    即使用 DCloud 公司的另一款产品 HBuilder,直接进行开发调试。

    SDK

    将 5+SDK 集成到自己的原生应用中,就可以在应用中使用其扩展的 JS API。

    区别

    简单地理解下
    Runtime 方式,不需要开发者自己开发原生应用的基座部分,5+ 这边帮开发者做好了,只需要提交应用资源云端打包就行了。
    SDK 方式则不同,这种情况是在原有的原生应用基座基础上,扩展 5+SDK。因而,需要开发者自己搭建原生开发的环境,进行部分原生开发的工作。

    基本架构

    按照官方的文档说明 Android平台第三方插件开发指导,大体分为三层结构。这里为了更方便理解,扩展成四部分进行说明。

    Webview

    可以理解为简单的浏览器,HTML、CSS、JavaScript 都在这里。

    plus

    这部分在 Webview 中,在原有的浏览器环境基础上,扩展可以调用原生功能的 API,这些 API 都在 window.plus 这个对象里面。

    JS Bridge

    负责连接 JavaScript 层与 Native 层。

    Native

    即 Android 和 iOS,也是 HTML5plus 的核心关键部分。

    一次调用执行的过程

    以获取应用版本号为例

    plus.runtime.version;
    1. JS 层调用 plus.runtime.version,Webview 向 JS Bridge 发起请求。

    2. JS Bridge 接收请求,通知 Native 层读取应用版本号信息。

    3. Native 层执行拿到结果,通知 JS Bridge 层相应结果。

    4. JS Bridge 拿到 Native 层相应的结果,通知相应的 Webview 结果信息。

    5. JS 层获取到应用的版本信息。

    吐槽一下

    个人认为,每个产品每家公司,都有其自身的设计理念以及经营策略。不同的用户,总会有不同的需求和看法。
    因此,做技术选型时一定要搞清楚自己的需求和被调研的产品信息。DCloud 的社区中,经常出现“怎么没有XXX API”,“为什么不集成XXX SDK”,“不会原生开发,希望官方能够扩展XXX API”等等类似的帖子。至于出现此类问题的具体原因,大家都有自己的理解,这里不做讨论。
    做技术选型时,最好亲自动手做下尝试。不要期望产品供应方给你最佳答复,因为人家不会傻傻地把用户往外推。
    ------华丽丽分割线------
    下面,分享一下个人使用的经验和心得,希望可以帮助其他开发者在技术选型时做个参考。

    优点

    1. 学习成本低,只要掌握了基本的 web 开发能力,即可上手。

    2. 云端打包,不必本地搭建 Android 与 iOS 开发环境,进行打包处理。

    3. 一套代码,只要做少许的兼容处理,即可编译成 Android 和 iOS 两个包。

    4. 没有想到,待讨论补充吧。

    不足

    1. plus.ModuleName.* 提供的 API 有限,虽然有 Native.js 这一产品,但是需要掌握一定的原生开发能力。

    2. 依赖手机自身的 Webview,因此在部分手机上性能并不理想。这一点,对于某些业务产品有一定的影响。

    3. 接第1点,某些功能的实现,需要开发者自行集成 SDK 进行扩展。例如蓝牙、应用后台常驻等。这一点,同样需要开发者具有原生开发的能力。

    4. 部分功能,由于兼容性问题实现的并不完善。例如桌面图标的角标等。当然,Android 的碎片化严重,有些不足可以理解。

    5. 文档内容,有些地方解释地不够清楚。另外,文档的排版有点奇怪。

    6. 目前没遇到其它坑了,也可能在下还不够熟悉。

    较合适范围

    综合官方的案例展示,以及个人开发的经历。总结下来,5+App 开发比较适合以下情况或产品:

    不推荐情况

    有些情况没办法一概而论,因而按照具体情形说明。

    上面许多情况都需要通过原生层的开发来解决,当然同时可以集成 5+SDK,相关的扩展 API 照用不误。

    同类产品

    目前在下了解到的就这些,有些产品浅尝辄止,有些产品压根就没体验过,因此这里不做对比以及过多的评述。

    补充:

    相关推荐:

    如何使用微信开发者移动应用创建获取APP ID的详细介绍(图)

    以上就是HTML5plus移动应用的开发实例分享的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:HTML5plus 开发实例 h5
    上一篇:JS代码实现瀑布流插件 下一篇:H5同层Video播放器接入实例分享
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 开发人员所需要知道的HTML5性能分析面面观_html5教程技巧• HTML5 微格式和相关的属性名称_html5教程技巧• HTML5 的普及需要具备哪些因素?• 为什么html5将主宰在线视频?• Html5 Canvas初探学习笔记(3) -绘制样式和绘制文本
    1/1

    PHP中文网