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 圆角效果
Jul 15 HTML / CSS
详解CSS透明opacity和IE各版本透明度滤镜filter的最准确用法
Dec 20 HTML / CSS
利用CSS3实现进度条的两种姿势详解
Mar 21 HTML / CSS
html5 touch事件实现触屏页面上下滑动(二)
Mar 10 HTML / CSS
canvas实现俄罗斯方块的方法示例
Dec 13 HTML / CSS
关于HTML5你必须知道的28个新特性,新技巧以及新技术
May 28 HTML / CSS
canvas使用注意点总结
Jul 19 HTML / CSS
HTML5+JS实现俄罗斯方块原理及具体步骤
Nov 29 HTML / CSS
HTML5 canvas基本绘图之绘制五角星
Jun 27 HTML / CSS
详解如何通过H5(浏览器/WebView/其他)唤起本地app
Dec 11 HTML / CSS
HTML5 FileReader对象的具体使用方法
May 22 HTML / CSS
bootstrapv4轮播图去除两侧阴影及线框的方法
Feb 15 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实现的网络相册图片防盗链完美破解方法
2015/07/01 PHP
详细解读PHP的Yii框架中登陆功能的实现
2015/08/21 PHP
php+ajax注册实时验证功能
2016/07/20 PHP
PHP中list方法用法示例
2016/12/01 PHP
window.ActiveXObject使用说明
2010/11/08 Javascript
js获取控件位置以及不同浏览器中的差别介绍
2013/08/08 Javascript
浅析javascript中function 的 length 属性
2014/05/27 Javascript
JS实现可缩放、拖动、关闭和最小化的浮动窗口完整实例
2015/03/04 Javascript
原生javascript实现的一个简单动画效果
2016/03/30 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
一个简易的js图片轮播效果
2017/07/22 Javascript
ui-router中使用ocLazyLoad和resolve的具体方法
2017/10/18 Javascript
小程序组件之仿微信通讯录的实现代码
2018/09/12 Javascript
nuxt中使用路由守卫的方法步骤
2019/01/27 Javascript
JS实现盒子跟着鼠标移动及键盘方向键控制盒子移动效果示例
2019/01/29 Javascript
JQuery中queue方法用法示例
2019/01/31 jQuery
vue elementUI 表单校验功能之数组多层嵌套
2019/06/04 Javascript
layui数据表格重载实现往后台传参
2019/11/15 Javascript
微信小程序实现限制用户转发功能的实例代码
2020/02/22 Javascript
vue watch监控对象的简单方法示例
2021/01/07 Vue.js
Python中map和列表推导效率比较实例分析
2015/06/17 Python
Python循环语句中else的用法总结
2016/09/11 Python
Python单例模式实例详解
2017/03/01 Python
简单谈谈python中的lambda表达式
2018/01/19 Python
python实现微信自动回复功能
2018/04/11 Python
Redis使用watch完成秒杀抢购功能的代码
2018/05/07 Python
解决Python pandas plot输出图形中显示中文乱码问题
2018/12/12 Python
春节到了 教你使用python来抢票回家
2020/01/06 Python
详解numpy1.19.4与python3.9版本冲突解决
2020/12/15 Python
CSS3系列之3D制作方法案例
2017/08/14 HTML / CSS
会计工作决心书
2014/03/11 职场文书
大学生个人求职信
2014/06/02 职场文书
投标授权委托书范文
2014/08/02 职场文书
村道德模范事迹材料
2014/08/28 职场文书
css 边框添加四个角的实现代码
2021/10/16 HTML / CSS
Vue+TypeScript中处理computed方式
2022/04/02 Vue.js