html5适合移动应用开发的12大特性


Posted in HTML / CSS onMarch 19, 2014

html5移动开发的出现让移动平台的竞争由系统平台转向了浏览器之间:移动端的IE、Chrome、FireFox、Safari,亦或是新出现的浏览器,谁能达到在移动端对HTML5更好的支持,谁就能在以后的移动应用领域占据更多的市场。
 
更灵活、更方便的app使用及安装方式将成为HT]L5在移动平台上大放异彩的保障之一。
 
下面列举HTML5适合移动应用开发的几大特性:
 
1.离线缓存为HTML5开发移动应用提供了基础
 
HTML5 Web Storage API可以看做是加强版的cookie,不受数据大小限制,有更好的弹性以及架构,可以将数据写入到本机的ROM中,还可以在关闭浏览器后再次打开时恢复数据,以减少网络流量。
同时,这个功能算得上是另一个方向的后台“操作记录”,而不占用任何后台资源,减轻设备硬件压力,增加运行流畅性。
在线app支持边使用边下载离线缓存,或者不下载离线缓存;而离线app必须是下载完离线缓存才能使用。
形象点说,cookie就是存了电话和菜单,想吃什么要叫外卖,等多长时间才能吃到就得看交通情况了;离线缓存就是直接在冰箱里存了食物,想吃就能马上吃到(当然,想吃最新的食物同样可以打电话预定)。
设计师要知道,什么时候让用户下载离线缓存(注意在线和离线app的区别)。
 
2.音频视频自由嵌入,多媒体形式更为灵活
 
原生开发方式对于文字和音视频混排的多媒体内容处理相对麻烦,需要拆分开文字、图片、音频、视频,解析对应的URL并分别用不同的方式处理。
HTML5在这个方面完全不受限制,可以完全放在一起进行处理。
设计师要知道,如果新闻类、微博类、社交类应用的信息呈现中实现文字与多媒体混排,而不用专门嵌入webview,将是一件多美好的事情,至少现在原生方式实现起来还有困难。

3.地理定位,随时随地分享位置
 
充分发挥移动设备对定位上的优势,推动LBS应用发展。
可以综合使用GPS、wifi、手机等方式让定位更为精准、灵活。
地理位置定位,让定位和导航不再专属导航软件,地图也不用下载非常大的地图包,可以通过缓存来解决,到哪儿下哪儿,更灵活。
设计师要知道,现在嵌入LBS功能的应用越来越多,这也是移动设备与台式PC相比最大的优势之一,HTML5能把这个优势再度扩大化,好好想想怎么在你设计的应用里用上吧!

4.Canvas绘图,提升移动平台的绘图能力
 
使用Canvas API可以简单绘制热点图收集用户体验资料
支持图片的移动、旋转、缩放等常规编辑
Canvas – 2D的绘图功能支持
Canvas 3D – 3D的绘图功能支持
SVG – 向量图支援
设计师要知道,图片的移动、旋转、缩放?那都太基础了,自己画都是小case,至于怎么用,好好想想吧!
 
5.专为移动平台定制的表单元素
 
浏览器中出现的html5表单元素与对应的键盘:
类型用途键盘
Text正常输入内容标准键盘
Tel电话号码数字键盘
Email电子邮件地址文本框带有@和.的键盘
url网页的URL带有.com和.的键盘
Search用于搜索引擎,比如在站点顶部显示的搜索框标准键盘
range特定值范围内的数值选择器,典型的显示方式是滑动条滑动条或转盘
只需要简单的声明 即可完成对不同样式键盘的调用,简捷方便。
设计师要知道,用的时候记得告诉研发同事一声!
 
6.丰富的交互方式支持
 
提升互动能力:拖拽、撤销历史操作、文本选择等
Transition – 组件的移动效果
Transform – 组件的变形效果
Animation – 将移动和变形加入动画支持
设计师要知道,HTML5提供的交互方式是非常丰富的,至于用不用得上,那是你自己的事儿喽!

7.HTML5使用上的优势
 
更低的开发及维护成本;
使页面变得更小,减少了用户不必要的支出;而且,性能更好使耗电量更低;
方便升级,打开即可使用最新版本,免去重新下载升级包的麻烦,使用过程中就直接更新了离线缓存。
设计师要知道,用户想要什么,HTML5能提供给用户什么。
 
8.CSS3 视觉设计师的辅助利器
 
CSS3支持了字体的嵌入、版面的排版,以及最令人印象深刻的动画功能。
Selector – 更有弹性的选择器
Webfonts – 嵌入式字体
Layout – 多样化的排版选择
Stlying radius gradient shadow – 圆角、渐变、阴影
Border background – 边框的背景支持
使用CSS3来完成部分视觉工作,载入速度快,节省代码及图片,也为用户节约了带宽。
设计师要知道,一个界面里几十张素材图的方式已经太out啦,赶快让CSS3帮你偷懒。
 
9.实时通讯
 
以往网站由于HTTP协议以及浏览器的设计,实时的互动性相当的受限,只能使用一些技巧来「仿真」实时的通讯效果,但HTML5提供了完善的实时通讯支持。
设计师要知道,应用中嵌入实时通信、信息内容进行实时提醒,HTML5可以帮你实现。
 
10.档案以及硬件支持
 
不知道大家有没有发现,在Gmail等新的网页程序当中,已经可以透过拖拉的方式将档案作为邮件附件?这就是HTML5档案的功能中的Drag’n Drop和File API。
设计师要知道,移动应用中对于数据传输的需求越来越大,传统的路径选择方式太过于繁琐,快来试试HTML5的拖拽上传功能吧!
 
11.语意化
 
语意化的网络是可以让计算机能够更加理解网页的内容,对于像是搜索引擎的优化(SEO)或是推荐系统可以有很大的帮助。
设计师要知道,HTML5能让搜索更快速、更准确。
 
12.双平台融合的app开发方式,提高工作效率
 
依照目前iPhone/Android 迅速提升市占率的情势来看,未来如果想要在先进的智慧型手机上撰写应用程式,要不是选择使用Objective-C + CocoaTouch Framework 撰写iPhone/iPad 应用程式,就是选择Java + Android Framework 撰写Android 应用程式,如果想要同时支援两种平台,势必要维护两套程式码,对于刚起步的小服务而言也算是个小有负担的维运成本。
 
使用HTML5, CSS3 来撰写Web-based 的应用程式,若要同时支援iPhone 及Android,几乎只需要维护一份程式码(少部份要因应clients 作修改),而且未来若有其它行动装置拥有支援HTML5 的浏览器,那同样的WebApp 直接就多了一个支援平台。
 
Google 的系列服务使用了不少HTML5 中的cache、storage 及database 规格来做到离线存取程式的效果。因为比起桌面应用程式,行动装置的网路连线更不稳定,而且有时在移动中并无网路可以使用,透过这些技术才能让使用者即使在无网路环境下继续使用你的webapp。这说明html5主要服务对象还是给予web的应用,并不会对全部app开发造成威胁,这样有利于不同类型应用使用不同的开发方式,灵活性更强。

HTML / CSS 相关文章推荐
CSS3弹性伸缩布局之box布局
Jul 12 HTML / CSS
CSS3中HSL和HSLA的简单使用示例
Jul 14 HTML / CSS
CSS3制作hover下划线动画
Mar 27 HTML / CSS
CSS3 清除浮动的方法示例
Jun 01 HTML / CSS
详解Html5微信支付爬坑之路
Jul 24 HTML / CSS
HTML5 Canvas——用路径描画线条实例介绍
Jun 09 HTML / CSS
html5中canvas图表实现柱状图的示例
Nov 13 HTML / CSS
HTML5 视频播放(video),JavaScript控制视频的实例代码
Oct 08 HTML / CSS
HTML5的postMessage的使用手册
Dec 19 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
May 14 HTML / CSS
基于CSS制作创意端午节专属加载特效
Jun 01 HTML / CSS
html网页引入svg图片的4种方式
Aug 05 HTML / CSS
用html5实现语音搜索框的方法
Mar 18 #HTML / CSS
HTMl5的存储方式sessionStorage和localStorage详解
Mar 18 #HTML / CSS
HTML5 Notification(桌面提醒)功能使用实例
Mar 17 #HTML / CSS
让IE9以下版本的浏览器兼容HTML5的方法
Mar 12 #HTML / CSS
HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影
Mar 07 #HTML / CSS
HTML5中新标签和常用标签详解
Mar 07 #HTML / CSS
html5的websockets全双工通信详解学习示例
Feb 26 #HTML / CSS
You might like
php数组函数序列之sort() 对数组的元素值进行升序排序
2011/11/02 PHP
ThinkPHP学习笔记(一)ThinkPHP部署
2014/06/22 PHP
什么情况下可以不写PHP的闭合标签“?>”
2014/08/28 PHP
PHP使用CURL模拟登录的方法
2015/07/08 PHP
Zend Framework入门教程之Zend_Config组件用法详解
2016/12/09 PHP
php获取当前url地址的方法小结
2017/01/10 PHP
ThinkPHP整合datatables实现服务端分页的示例代码
2018/02/10 PHP
Laravel5.5 数据库迁移:创建表与修改表示例
2019/10/23 PHP
thinkphp5框架路由原理与用法详解
2020/02/11 PHP
windows系统下简单nodejs安装及环境配置
2013/01/08 NodeJs
Js base64 加密解密介绍
2013/10/11 Javascript
浅析JavaScript中两种类型的全局对象/函数
2013/12/05 Javascript
分享9个最好用的JavaScript开发工具和代码编辑器
2015/03/24 Javascript
jQuery简单实现日历的方法
2015/05/04 Javascript
js漂浮广告实现代码
2015/08/15 Javascript
详解JavaScript中的4种类型识别方法
2015/09/14 Javascript
JavaScript实现页面跳转的几种常用方式
2015/11/28 Javascript
谈一谈javascript中继承的多种方式
2016/02/19 Javascript
理解javascript正则表达式
2016/03/08 Javascript
jQuery中事件与动画的总结分享
2016/05/24 Javascript
AngularJS实现按钮提示与点击变色效果
2016/09/07 Javascript
微信小程序 网络请求(post请求,get请求)
2017/01/17 Javascript
JavaScript实现公历转农历功能示例
2017/02/13 Javascript
Vue 2.0 服务端渲染入门介绍
2017/03/29 Javascript
Node.js的Koa实现JWT用户认证方法
2018/05/05 Javascript
微信小程序实现一张或多张图片上传(云开发)
2019/09/25 Javascript
浅谈Python中的全局锁(GIL)问题
2019/01/11 Python
在python中利用opencv简单做图片比对的方法
2019/01/24 Python
解决jupyter notebook import error但是命令提示符import正常的问题
2020/04/15 Python
大学生学习生活的自我评价
2013/11/01 职场文书
计算机专业推荐信范文
2013/11/27 职场文书
安全月活动总结
2014/05/05 职场文书
公司老总年会致辞
2015/07/30 职场文书
导游词之台湾阿里山
2019/10/23 职场文书
redis 限制内存使用大小的实现
2021/05/08 Redis
前端JS获取URL参数的4种方法总结
2022/04/05 Javascript