纯原生 App开发模式还能走多久?

文中涉及到的几个概念(信息来自百度百科和百度知道):
  • Native App(原生APP)开发:该开发针对IOS、Android等不同的手机操作系统要采用不同的语言和框架进行开发,该模式通常是由“云服务器数据+APP应用客户端”两部份构成,APP应用所有的UI元素、数据内容、逻辑框架均安装在手机终端上。
  • Web App开发:即是一种框架型APP开发模式(HTML5 APP 框架开发模式),该开发具有跨平台的优势,该模式通常由“HTML5云网站+APP应用客户端”两部份构成,APP应用客户端只需安装应用的框架部份,而应用的数据则是每次打开APP的时候,去云端取数据呈现给手机用户。
  • Hybrid App:是指介于web-app、native-app这两者之间的app,它虽然看上去是一个Native App,但只有一个UI WebView,里面访问的是一个Web App。

一、Web App体验

最近因为比赛需要,由于时间不怎么充裕,便利用PHP写了服务器端,jQuery Mobile写了一个整个 APP的框架(只是简单的框架)和内容,然后再借助android的WebView控件显示页面,就这样传说中的Web App就新鲜出炉了。当然这只是简单的一个小应用,真正的Web App开发还牵涉到更多的知识,这里我们不做讨论。

Web App
Web App

虽然是如此简单的一个小应用,却也五脏俱全。实现了按钮,页面切换,列表信息显示等功能。而且想要更改页面布局或者内容,直接在服务器端更改,更改后不用重新打包,打开APP就能直接更新。
综上所述,Web App有以下几个特点

  • (1) 框架型APP应用的安装包小巧,只包含框架文件,而大量的UI元素、数据内容刚存放在服务器端;
  • (2) APP用户每次都可以访问到实时的最新的服务器端数据;
  • (3)APP用户无须频繁更新APP应用,与服务器端实现的是实时数据交互;
    Web App虽然开发起来简单好用,但是随着需要用到的涉及手机的功能越来越多,Web App渐渐显得力不从心了,于是只好采用Native App开发。

二、Native App开发

因为是一个人开发,为了开发节省时间,我便开始在网上疯狂的找APP框架。一开始感觉怎么着也得是那种狂拽酷炫屌炸天的效果吧,运行了一个有一个,却发现很多都是徒有其表,为了效果把代码弄的是各种复杂,实用性一点都不强。只好退而求其次,找简单的。
终于找到一个合适的,又费了半天的功夫调试安装后却发现资料不全,能不能继续下去都是个问题。很想放弃然而已经花费了这么多的精力不能说放弃就放弃吧,于是就咬着牙把代码重新梳理整合了一下,总算把整体框架搭建好了,不过想要调用之前的脚本实现与服务器端交互,效果却不是很理想,只能重新构建服务器端逻辑了,造成的结果是生成的APP应用的安装包是之前的两倍多。

Demo来自javaapk

综上所述,Native App有以下几个特点:

  • (1)原生型APP应用的安装包相对较大,包含UI元素、数据内容、逻辑框架;
  • (2)手机用户无法上网也可访问APP应用中以前下载的数据。
  • (3)原生型的APP可以调用手机终端的硬件设备(语音、摄像头、短信、GPS、蓝牙、重力感应等)

三、Hybrid App开发

如你所见,Web APP无法调用手机终端的硬件设备,访问速度受手机终端上网的限制,而Native App虽然可以充分利用设备的特性,但是开发起来难度和代价却大。Hybrid App却综合了二者的特点。下面就一ionic的使用体验,谈谈Hybrid App开发体验。

图片来自百度百科

ionic 是一个专注于用WEB开发技术,基于HTML5创建类似于手机平台原生应用的一个开发框架。绑定了AngularJS和Sass。这个框架的目的是从web的角度开发手机应用,基于PhoneGap的编译平台,可以实现编译成各个平台的应用程序。

首先安装ionic,确保电脑已经安装:Node.js(下载包),JDK(webstorm 运行环境),Android SDK (Android编译),Android Studio。(具体教程请参照 轻松学习Ionic (一) 搭建开发环境,并创建工程

$ npm install -g ionic cordova
$ionic start iotApp tabs
cd iotApp
ionic platform add android 
创建APP

然后,打开Android studio导入E:\Android\iotApp\platforms\android(这是本人电脑上的路径),导入后就可以编辑APP了。

android studio
APP效果

如你所见,仅仅修改HTML文件就可以直接在APP上显示了,当然还有很多功能等待大家探索,本人只是抛砖引玉。

四、总结

虽然水平有限,只是简单地带大家和我一起体验了三种开发方式,现在回到原题(不然会被骂标题党的),那么纯Native App开发模式还能走多久呢?个人觉得随着技术的更新迭代应该走不了多久,虽然最近“微软发招、苹果发飙:React Native遭躺枪”这样的新闻很火(PS.React Native也是一个移动应用开发框架),但是还是阻挡不了混合应用开发的脚步。

图片来自Cordova官网

上面这张图片可以看出,Hybrid App的原生体验相对于Web App,已经有了不小的进步,再加上其对JS与生俱来的支持,相信不久的将来其体验会越来越好。

以上仅属于个人实际体验和观点。最后以 Atwood定律结尾:

凡是能用JavaScript写出来的,最终都会用JavaScript写出来。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容