• h5做的app和原生app的区别


    之所以说h5做的app和原生app的区别,是因为一位博友的问题:

    随着 h5 的普及,是不是不再需要开发 app ?

    我的回答是要分业务需求,分场合而定。

    比如现在的微信小程序这么流行,甚至也取代了不少app,但是为什么还是要开发app呢?

    以我个人的想法,主要认为

    性能是一个非常大的问题(微信小程序的功能与App相比,App功能丰富的前提下,还可以确保性能,而微信小程序与同h5开发的app一样,性能始终是一个不可跨越的问题,不过根据摩尔定律,十八个月处理器性能提高,价格下降,以后性能也许不再是一个问题。其实之所以微信小程序流行,在于微信普遍的使用及其广大的用户量);

    下面进入正题:

    H5开发的web APP和原生APP的区别有以下几个方面(引用一位朋友说的),我认为这位朋友说的比较全面:
    一、开发方面
    原生App
    ⊙ 每一种移动操作系统都需要独立的开发项目
    ⊙ 每种平台都需要独立的开发语言。Java(Android), Objective-C(iOS)以及C++(Windows Mobile)等等
    ⊙ 需要使用各自的软件开发包,开发工具以及各自的控件

    移动Web App
    ⊙ 因为运行在移动设备的浏览器上,所以只需要一个开发项目
    ⊙ 这种应用可以使用HTML5,CSS3以及JavaScript以及服务端语言语言来完成(PHP,Ruby on Rails,Python)
    ⊙ 这里可没有标准的SDK,基本任意选择,别忘了有一些跨平台的开发工具,比如PhoneGap, Sencha Touch 2,APPcan以及Appcelerator Titanium等等。

    二、能力方面
    原生App
    ⊙ 能够与移动硬件设备的底层功能,比如个人信息,摄像头等等

    移动Web App
    ⊙ 只能使用有限的移动硬件设备功能。

    三、获取方法
    原生App
    ⊙ 直接下载到设备
    ⊙ 以独立的应用程序运行(并不需要浏览器)
    ⊙ 用户必须手动去下载并安装这些原生App
    ⊙ 有一些商店与卖场来帮助用户寻找你的App,目前app市场不计其数

    移动Web App
    ⊙ 从移动设备上的浏览器访问
    ⊙ 不需要安装额外的软件
    ⊙ 软件更新只需要服务器就够了
    ⊙ 因为现在没有什么商品或卖场提供这种App,所以如何搜索这些移动Web App相当不简单。

    四、版本控制
    原生App
    ⊙ 用户可以自由地选择是否更新软件版本,所以会出现不同用户同时使用不同版本的情况

    移动Web App
    ⊙ 所有的用户都是用同样的版本

    五、优势
    原生App

    ⊙ 比移动Web App运行快
    ⊙ 一些商店与卖场会帮助用户寻找原生App
    ⊙ 官方卖场的应用审核流程会保证让用户得到高质量以及安全的App
    ⊙ 官方会发布很多开发工具或者人工支持来帮助你的开发

    移动Web App
    ⊙ 跨平台开发
    ⊙ 用户不需要去卖场来下载安装App
    ⊙ 任何时候都可以发布App,因为根本不需要官方卖场的审核
    ⊙ 如果你已经有了一个Web App,你可以使用 responsive web design来辅助改进

    六、缺陷
    原生App
    ⊙ 开发成本高,尤其是当需要多种移动设备来测试时
    ⊙ 因为是不同的开发语言,所以开发,维护成本也高
    ⊙ 因为用户使用的App版本不同,所以你维护起来很困难
    ⊙ 官方卖场审核流程复杂且慢,会严重影响你的发布进程

    移动Web App
    ⊙ 无法使用很多移动硬件设备的独特功能
    ⊙ 要同时支持多种移动设备的浏览器让开发维护的成本也不低
    ⊙ 如果用户使用更多的新型浏览器,那问题就更不好处理了
    ⊙ 对于用户来说,这种App很难被用户发现

    附:原生App 与 移动Web App:您如何选择?
    所以在你准备做移动App时,你应该先问问自己以下几个问题:

    1. 你的应用是否需要使用某些设备的特殊功能,比如摄像头,摄像头闪光灯等
    2. 你的开发预算是多少?
    3. 你的应用是否一定需要网络
    4. 你的应用的目标硬件设备是所有的移动设备还是仅仅只是一部分而已
    5. 你自己已经熟悉的开发语言
    6. 这个应用对于性能要求是否苛刻
    7. 如何靠这个应用赢利

  • 相关阅读:
    Linux基础命令---chfn
    第二十一课:js属性操作的兼容性问题
    jquery源码解析:jQuery工具方法Callbacks详解
    第二十课:js中如何操作元素的属性系统
    第十七课:js数据缓存系统的原理
    jquery源码解析:proxy,access,swap,isArraylike详解
    第十九课:盒子模型
    jquery源码解析:each,makeArray,merge,grep,map详解
    第十八课:js样式操作需要注意的问题
    下拉框插件的详解
  • 原文地址:https://www.cnblogs.com/youcong/p/9721005.html
Copyright © 2020-2023  润新知