HTML5 vs mobile App

admin 13年前
     <p><img title="1.png" border="0" alt="1.png" src="https://simg.open-open.com/show/76ecfcc35dcf52cc83577bcb535d3cb5.jpg" /></p>    <p><strong> 前言</strong></p>    <p> HTML5的出现让移动平台的竞争由系统平台转向了浏览器之间:移动端的IE、Chrome、FireFox、Safari,亦或是新出现的浏览器,谁能达到在移动端对HTML5更好的支持,谁就能在以后的移动应用领域占据更多的市场。</p>    <p><span id="more-7136"><img title="2.jpg" border="0" alt="2.jpg" src="https://simg.open-open.com/show/eee3356eabf69caa26fa627417de6c75.jpg" /></span></p>    <p> 现在我们怎么装APP</p>    <p><img title="3.png" border="0" alt="3.png" src="https://simg.open-open.com/show/b0a731793329d5cfdccdca20be61337a.jpg" /></p>    <p> 有了HTML5以后怎么装APP</p>    <p><img title="4.png" border="0" alt="4.png" src="https://simg.open-open.com/show/4f1fba53ef83177dc8ac7ad007ba6b04.jpg" /></p>    <p> 更灵活、更方便的app使用及安装方式将成为HTML5在移动平台上大放异彩的保障之一。</p>    <h2> 下面列举HTML5适合移动应用开发的几大特性:</h2>    <p> <strong>1.离线缓存为HTML5开发移动应用提供了基础</strong></p>    <p> HTML5 Web Storage API可以看做是加强版的cookie,不受数据大小限制,有更好的弹性以及架构,可以将数据写入到本机的ROM中,还可以在关闭浏览器后再次打开时恢复数据,以<strong>减少网络流量</strong>。</p>    <p> 同时,这个功能算得上是另一个方向的后台“操作记录”,而<strong>不占用任何后台资源</strong>,减轻设备硬件压力,增加运行流畅性。</p>    <p> 在线app支持边使用边下载离线缓存,或者不下载离线缓存;而离线app必须是下载完离线缓存才能使用。</p>    <p> 形象点说,cookie就是存了电话和菜单,想吃什么要叫外卖,等多长时间才能吃到就得看交通情况了;离线缓存就是直接在冰箱里存了食物,想吃就能马上吃到(当然,想吃最新的食物同样可以打电话预定)。</p>    <p> 设计师要知道,什么时候让用户下载离线缓存(注意在线和离线app的区别)。</p>    <p> <strong>2.音频视频自由嵌入,多媒体形式更为灵活</strong></p>    <p> 原生开发方式对于文字和音视频混排的多媒体内容处理相对麻烦,需要拆分开文字、图片、音频、视频,解析对应的URL并分别用不同的方式处理。</p>    <p> HTML5在这个方面完全不受限制,可以完全放在一起进行处理。</p>    <p> 设计师要知道,如果新闻类、微博类、社交类应用的信息呈现中实现文字与多媒体混排,而不用专门嵌入webview,将是一件多美好的事情,至少现在原生方式实现起来还有困难。</p>    <p><strong> 3.地理定位,随时随地分享位置</strong></p>    <p> 充分发挥移动设备对定位上的优势,推动LBS应用发展。</p>    <p> 可以综合使用GPS、wifi、手机等方式让定位更为精准、灵活。</p>    <p> 地理位置定位,让定位和导航不再专属导航软件,地图也不用下载非常大的地图包,可以通过缓存来解决,到哪儿下哪儿,更灵活。</p>    <p> 设计师要知道,现在嵌入LBS功能的应用越来越多,这也是移动设备与台式PC相比最大的优势之一,HTML5能把这个优势再度扩大化,好好想想怎么在你设计的应用里用上吧!</p>    <p> <strong> 4.Canvas绘图,提升移动平台的绘图能力</strong></p>    <p> 使用Canvas API可以简单绘制热点图收集用户体验资料</p>    <p> 支持图片的移动、旋转、缩放等常规编辑</p>    <p> Canvas – 2D的绘图功能支持</p>    <p> Canvas 3D – 3D的绘图功能支持</p>    <p> SVG – 向量图支援</p>    <p> 设计师要知道,图片的移动、旋转、缩放?那都太基础了,自己画都是小case,至于怎么用,好好想想吧!</p>    <p> <strong> 5.专为移动平台定制的表单元素</strong></p>    <p> 浏览器中出现的html5表单元素与对应的键盘:</p>    <table border="1" cellspacing="0" cellpadding="0" width="656" height="167">     <tbody>      <tr>       <td valign="top" width="66">类型</td>       <td valign="top" width="350">用途</td>       <td valign="top" width="136">键盘</td>      </tr>      <tr>       <td valign="top" width="66">Text</td>       <td valign="top" width="350">正常输入内容</td>       <td valign="top" width="136">标准键盘</td>      </tr>      <tr>       <td valign="top" width="66">Tel</td>       <td valign="top" width="350">电话号码</td>       <td valign="top" width="136">数字键盘</td>      </tr>      <tr>       <td valign="top" width="66">Email</td>       <td valign="top" width="350">电子邮件地址文本框</td>       <td valign="top" width="136">带有@和.的键盘</td>      </tr>      <tr>       <td valign="top" width="66">url</td>       <td valign="top" width="350">网页的URL</td>       <td valign="top" width="136">带有.com和.的键盘</td>      </tr>      <tr>       <td valign="top" width="66">Search</td>       <td valign="top" width="350">用于搜索引擎,比如在站点顶部显示的搜索框</td>       <td valign="top" width="136">标准键盘</td>      </tr>      <tr>       <td valign="top" width="66">range</td>       <td valign="top" width="350">特定值范围内的数值选择器,典型的显示方式是滑动条</td>       <td valign="top" width="136">滑动条或转盘</td>      </tr>     </tbody>    </table>    <p> 只需要简单的声明 <input type=”email”> 即可完成对不同样式键盘的调用,简捷方便。</p>    <p> 设计师要知道,用的时候记得告诉研发同事一声!</p>    <p><img title="5.png" border="0" alt="5.png" src="https://simg.open-open.com/show/f6b8f6a650bed90e25d52b40b5059b1e.jpg" /></p>    <p><strong> 6.丰富的交互方式支持</strong></p>    <p> 提升互动能力:拖拽、撤销历史操作、文本选择等</p>    <p> Transition – 组件的移动效果</p>    <p> Transform – 组件的变形效果</p>    <p> Animation – 将移动和变形加入动画支持</p>    <p> 设计师要知道,HTML5提供的交互方式是非常丰富的,至于用不用得上,那是你自己的事儿喽!</p>    <p> <strong> 7.HTML5使用上的优势</strong></p>    <p> 更低的开发及维护成本;</p>    <p> 使页面变得更小,减少了用户不必要的支出;而且,性能更好使耗电量更低;</p>    <p> 方便升级,打开即可使用最新版本,免去重新下载升级包的麻烦,使用过程中就直接更新了离线缓存。</p>    <p> 设计师要知道,用户想要什么,HTML5能提供给用户什么。</p>    <p> <strong> 8.CSS3 视觉设计师的辅助利器</strong></p>    <p> CSS3支持了字体的嵌入、版面的排版,以及最令人印象深刻的动画功能。</p>    <p> Selector – 更有弹性的选择器</p>    <p> Webfonts – 嵌入式字体</p>    <p> Layout – 多样化的排版选择</p>    <p> Stlying radius gradient shadow – 圆角、渐变、阴影</p>    <p> Border background – 边框的背景支持</p>    <p> 使用CSS3来完成部分视觉工作,载入速度快,节省代码及图片,也为用户节约了带宽。</p>    <p> 设计师要知道,一个界面里几十张素材图的方式已经太out啦,赶快让CSS3帮你偷懒。</p>    <p><img title="6.jpg" border="0" alt="6.jpg" src="https://simg.open-open.com/show/703ed2b6a8fba628fc7cf8c5d532cbdd.jpg" /></p>    <p><strong> 9.实时通讯</strong></p>    <p> 以往网站由于HTTP协议以及浏览器的设计,实时的互动性相当的受限,只能使用一些技巧来「仿真」实时的通讯效果,但HTML5提供了完善的实时通讯支持。</p>    <p> 设计师要知道,应用中嵌入实时通信、信息内容进行实时提醒,HTML5可以帮你实现。</p>    <p> <strong> 10.档案以及硬件支持</strong></p>    <p> 不知道大家有没有发现,在Gmail等新的网页程序当中,已经可以透过拖拉的方式将档案作为邮件附件?这就是HTML5档案的功能中的Drag’n Drop和File API。</p>    <p> 设计师要知道,移动应用中对于数据传输的需求越来越大,传统的路径选择方式太过于繁琐,快来试试HTML5的拖拽上传功能吧!</p>    <p> <strong> 11.语意化</strong></p>    <p> 语意化的网络是可以让计算机能够更加理解网页的内容,对于像是搜索引擎的优化(SEO)或是推荐系统可以有很大的帮助。</p>    <p> 设计师要知道,HTML5能让搜索更快速、更准确。</p>    <p> <strong> 12.双平台融合的app开发方式,提高工作效率</strong></p>    <p> 依照目前iPhone/Android 迅速提升市占率的情势来看,未来如果想要在先进的智慧型手机上撰写应用程式,要不是选择使用Objective-C + CocoaTouch Framework 撰写iPhone/iPad 应用程式,就是选择Java + Android Framework 撰写Android 应用程式,如果想要同时支援两种平台,势必要维护两套程式码,对于刚起步的小服务而言也算是个小有负担的维运成本。</p>    <p> 使用HTML5, CSS3 来撰写Web-based  的应用程式,若要同时支援iPhone 及Android,几乎只需要维护一份程式码(少部份要因应clients 作修改),而且未来若有其它行动装置拥有支援HTML5 的浏览器,那同样的WebApp 直接就多了一个支援平台。</p>    <p> Google 的系列服务使用了不少HTML5 中的cache、storage 及database 规格来做到离线存取程式的效果。因为比起桌面应用程式,行动装置的网路连线更不稳定,而且有时在移动中并无网路可以使用,透过这些技术才能让使用者即使在无网路环境下继续使用你的webapp。这说明html5主要服务对象还是给予web的应用,并不会对全部app开发造成威胁,这样有利于不同类型应用使用不同的开发方式,灵活性更强。</p>    <h2> 关于HTML5,设计师要知道些神马</h2>    <p> 对于设计师,了解HTML5并不是要学会写代码,而是要知道HTML5有什么特性,能实现什么效果,以便在设计过程中熟练应用。</p>    <p> 除此之外,需要知道哪些产品适合使用HTML5进行开发,哪些适合使用原生方式进行开发,毕竟最快、最方便的开发方式是最好的。</p>    <p> 再进一步,原生&HTML5的符合开发方式会逐步成为潮流,哪个部分最适合使用HTML5进行开发,也应该能够分辨出来。</p>    <h3><strong> 什么类型的应用最适合用HTML5</strong><strong>开发</strong></h3>    <p> 就目前来说,依托于网络,web上已经出现的,基于<strong>信息流</strong>方式及类似方式的应用最适合使用HTML5进行开发。</p>    <p> 什么应用是这样的:<strong>微博</strong>、<strong>社交</strong>、<strong>新闻</strong>等</p>    <p> 其他适合使用HTML5开发的应用类型:<strong>地图</strong>、<strong>导航</strong>等</p>    <h3><strong> 为什么用HTML5</strong><strong>会更好</strong></h3>    <p> 信息流架构应用都是直接在web(或wap)端抓取数据,HTML5可以直接使用跨平台数据而不用使用后台API,大大降低研发、维护成本,而且呈现效果几乎没有什么区别</p>    <p> 地图类能充分发挥HTML5对于离线缓存及地理定位方面的功能,将地图下载到本地,然后配合定位进行搜索、导航等功能(形式灵活,不用提前下载大容量的地图包,节省流量)</p>    <p> 下面介绍一些使用HTML5开发的web应用</p>    <p> google+</p>    <p><img title="7.png" border="0" alt="7.png" src="https://simg.open-open.com/show/c225a9fbe306f8d9b4134d7db6348818.jpg" /></p>    <p> 新浪微博</p>    <p><img title="8.png" border="0" alt="8.png" src="https://simg.open-open.com/show/8f16bc7953bfeed3c5afdfd260925489.jpg" /></p>    <p> 百度小说</p>    <p><img title="9.png" border="0" alt="9.png" src="https://simg.open-open.com/show/1a6412554d3367b576982d5df5b6a9b5.jpg" /></p>    <p> FT web app  app.ft.com</p>    <p><img title="10.png" border="0" alt="10.png" src="https://simg.open-open.com/show/23a283cd437588dbf2c9c51d67d907e7.jpg" /></p>    <p> 不停走动的倒计时器  <a href="/misc/goto?guid=4958187348871715338">http://www.technetra.com/ipdc3/countdown-2.0/</a></p>    <p><img title="11.png" border="0" alt="11.png" src="https://simg.open-open.com/show/58d2c9ea0bbaa8d7aa10c7b19a8aa132.jpg" /></p>    <p> 终端上实现素描效果  <a href="/misc/goto?guid=4958187349711214166">http://mrdoob.com/projects/harmony/</a></p>    <p><img title="12.png" border="0" alt="12.png" src="https://simg.open-open.com/show/d47a83449d9f964a5756ca135ba5f58e.jpg" /></p>    <p> 吃豆游戏iPhone版   <a href="/misc/goto?guid=4958187350449759825">http://www.kesiev.com/akihabara/</a></p>    <p><img title="13.png" border="0" alt="13.png" src="https://simg.open-open.com/show/e9481557ecd6046a117584826dc75e95.jpg" /></p>    <p> 图表实时绘制应用    <a href="/misc/goto?guid=4958187351187491916">http://dwpe.googlecode.com/svn/trunk/charting/index.html</a></p>    <p><img title="14.png" border="0" alt="14.png" src="https://simg.open-open.com/show/4a570b61ce789ebe9b3b41b8c66b0613.jpg" /></p>    <h3><strong> 怎么用HTML5</strong><strong>开发移动应用</strong></h3>    <p> 对于纯离线类的app,目前HTML5展现出来的实力还不是非常强劲,从交互体验和视觉呈现来说与原生方式开发的app还有一定的差距,希望随着HTML5的不断完善,能够赶超原生模式</p>    <p> 事实上,移动应用的开发方式往往不是那么死板只用一种方式的,HTML5配合原生方式可能会获得更好的效果:<strong>利用原生方式搭建本地架构</strong>,让用户获得更加贴近于设备的交互体验,同时<strong>在信息的呈现上使用</strong><strong>HTML5</strong>的优势,以强强联手的方式为用户打造最好的移动应用。</p>    <p><strong> 实例:网易博客Android</strong><strong>客户端</strong></p>    <p> <a href="/misc/goto?guid=4958187351923276894">http://www.mhtml5.com/2011/07/2200.html</a></p>    <h2><strong> HTML5</strong><strong>现状及展望</strong></h2>    <p> 现在HTML5的标准还没有完全定制完成,整体开发方式上还没有一个规范性的内容,导致的结果是开发者开发的应用比较混乱,体验上也不及原生方式开发的应用,如果想要更好的用户体验,需要更多的优化。</p>    <p> 对于移动设备硬件的接口API,目前使用HTML5还不能方便调用移动设备的摄像头、话筒、重力感应器、GPS等硬件设备,不过这也只是时间问题,相信随着HTML5的越发完善,这样的功能一定也会支持的。</p>    <p> 还有一个方面就是浏览器之争,一个全面强大的移动端浏览器将对HTML5在移动平台上的发展起到至关重要的作用。</p>    <p> Safari、Chrome、Firefox、IE…谁能脱颖而出,我们拭目以待。</p>    <p> 期待HTML5未来在移动平台散发炫目的光彩!</p>    <p> 由于目前网络上相关内容较少,以上内容多为自己总结,肯定有不太对的地方,还请大家多多指正。<br /> <br /> 来自: <a id="link_source2" href="/misc/goto?guid=4958187352650091015" target="_blank">uedc.163.com</a><br /> </p>