引言
随着智能手机的普及,移动端应用几乎成为每个互联网产品的标配。在快速迭代的互联网战场中高效开发、低成本上线产品,是每个应用开发团队追求的目标。此时,选择合适的应用类型和开发模式便至关重要。移动应用可以粗分为三种:原生应用(native app), 网页应用(web app,或HTML5 app),以及它们的混血儿——混合模式移动应用(hybrid app)。
- 现实案例
nativeAPP(原生APP):计算机,闹钟。
webAPP(网页APP):在浏览器中打开美团,这个页面就是网页APP。(百度、淘宝等都算)
hybridAPP(混合APP):微信,百度地图等。
- 优缺点对比
原生应用(nativeApp):
优点:
提供最佳用户体验,最优质的用户界面,流畅的交互
可以访问本地资源
可以调用移动硬件设备,比如摄像头、麦克风等
缺点:
开发成本高。每种移动操作系统都需要独立的开发项目,针对不同平台提供不同体验;
发布新版本慢。下载是用户控制的,很多用户不愿意下载更新(比如说,版本发布到了3.0,但还是有很多1.0的用户,你可能就得继续维护1.0版本的API)
应用商店发布审核周期长。安卓平台大概要1~3天,而iOS平台需要的时间更长
网页应用(webAPP):
优点:
不需要安装包,节约手机空间,生存在浏览器中的应用.
整体量级轻,开发成本低
不需要用户进行手动更新,由应用开发者直接在后台更新,推送到用户面前的都是全新版本,更便于业务的开展
基于浏览器,可以跨平台使用,基本上可以说是触屏版的网页应用。
缺点:
页面跳转费力,不稳定感更强。在网速受到限制时,很多时候出现卡顿或者卡死现象,交互效果受到限制
安全性相对较低,数据容易泄露或者被劫持.
混合应用(hybrid APP)
优点:
在实现更多功能的前提下,使得App安装包不至于过大。
在应用内部打开Web网页,省去了跳转浏览器的麻烦。
主要功能区相对稳定下,增加的功能区采用Web形式,使得迭代更加方便。
Web页面在用户设置不同的网络制式时会以不同的形式呈现。(以微信朋友圈为例:比如在数据流量下,设置APNS为WAP时,微信订阅号内容将屏蔽图片和视频。这样能为用户省去一部分流量,当然整个页面阅读就不那么友好了)。
缺点:
APP的Web部分可能是驻留在服务器上的网页,封装到App代码中,存储在设备本地。一方面是这个方法摈弃了任何离线可用性,因为设备与网络没有连接时,无法访问设备。
另一方面,把Web代码封装到APP里面可以提高性能和可访问性,但是不允许远程更新。
- 应用效率对比
4. 三种APP图解对比
native:
Objective-C/Swift(iOS),Java(Android),页面存放于本地。
hybrid:
Objective-C/Swift(iOS) +
HTML(受限于原生应用所提供的web控件,例如Xcode提供的UIWebView)
web:
HTML+CSS+Javascript, 页面放于服务器