和websocket服务器连接成功
'; }//接收到服务器返回的数据ws.onmessage = function(e){ systemInfo.innerHTML += ''+e.data+'
'; }//断开服务器连接ws.onclose = function(){ systemInfo.innerHTML += 'WebSocket服务器连接关闭
'; }//ws发生错误ws.onerror = function(e){ console.log(e); systemInfo.innerHTML += 'WebSocket发生错误
'; }对于webSocket,有兴趣了解更多的朋友直接转移到我的另外一篇文章《移动前端系列——websocket实时互动小游戏》websocket的数据发送和接收,其实也都是依赖于网络的,webSocket自己也对网络状况这块通过事件的方式做出了相应,比如说上面的onclose、onerror。但是就目前来说,很多页面上可能并没有用webSocket,这么一来,对于网络何时断开了,可能捕获就没那么容易了,更何况,webSocket在网络信息这块,可能还并不是那么的完美。比如说,我想获取当前连接的网络类型。网络类型这块我们暂且先放半分钟,我们先看一下如何动态判断网络连接是否断开,所指动态判断网络连接断开,指的是,页面不刷新的情况下,实时地知道当前网络是否可用。以往,我们想得到这种数据,我们一般的实现方法是通过轮询去访问服务器上的一个文件,如果文件正常响应,说明网络是通的;如果文件不响应,那么就认为网络是不通的。这种方式感觉挺靠谱,但是可以想象,轮询请求,会耗费多少服务器资源。下面这货出来之后,以往的这种方式就可以进博物馆了。onLine简介:判断当前网络是否有效用法也是相当地简单:if (navigator.onLine) { alert('online'); } else { alert('offline'); }我们可以通过事件的监听,去实时获取到网络状态的变化window.addEventListener('offline', function(e) {alert('offline');}) window.addEventListener('online', function(e) {alert('online');})这样以来,实时获取网络状态俨然和服务器已经没有半毛钱关系了。好了,半分钟时间已到,我们回头来看看我前面说的那个问题,获取网络类型,所指网络类型,值的是2G、3G、4G、蓝牙等等。其实,我个人觉得,这个网络类型完全可以放到online那个事件对象里面去。但是很遗憾,至少目前没放,暂不清楚是基于什么考虑的。我们目前想要获取这个网络类型,需要通过另外一个属性connectionconnection也是navigator的一个属性,他包含了一些当前连接的基本信息,其中connection.type值的就是当前的网络类型。其值包含了一下几个:bluetooth cellular ethernet none wifi wimax wimax unknown当网络类型发生变化时,同样的也是可以通过事件监听的方式来实时获取到网络类型。代码实现如下:var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection; var type = connection.type; function updateConnectionStatus() { alert("网络由 " + type + " 变化为 " + connection.type); } //监听网络类型发生变化 connection.addEventListener('typechange', updateConnectionStatus);有了这些,我们就可以根据不同的网络环境去加载不同的资源去最大程度上丰富用户体验。我们上面所提及到的,很多都是和网络(互联网)相关,但是有的时候,我们想在没有网络的环境下,也想传送一些数据该怎么办。这种情况可能在不久的将来,在我们的网页里面也能实现了,这个就是接下来的NFC(为什么我会想到KFC)NFC简介:近场通信/近距离无线通信技术。其实说实在的,这个功能我并没有在我的页面里面调试出来。主要的一个原因是~这货目前只是在firefox os系统里面的firefox浏览器里面实现了,手头上没这设备。不过从他们官网的例子中,我大概地可以感受得到这货的好用,有兴趣的同学自行前往学习:https://developer.mozilla.org/en-US/docs/Web/API/NFC_API/Using_the_NFC_API。当然了,如果你手头上刚好有两部带有NFC芯片的三星手机,可以试试。解锁屏幕,将两部三星手机后壳贴近,听见“滴”的一声后,注意看屏幕上的变化。然后点击屏幕,再去看看另外一个手机上发生了什么。清脆“滴”的一声,多好的用户行为反馈,忍不住还多尝试了几次,忽然就感觉这种靠声音的提醒,似乎忽略了一些失聪的人群。如果加上点震动的话~似乎就完美了。不是于是乎,咱们本片的最后一个话题引出。vibrate简介:设备震动核心代码:navigator.vibrate = navigator.vibrate || navigator.webkitVibrate || navigator.mozVibrate || navigator.msVibrate; navigator.vibrate(value); navigator.vibrate(0);vibrate的参数为震动的时间,如果值为0,说明停止震动值为一个数组的话,奇数项表示的是震动时间,偶数项表示的为间隔时间。比如:vibrate(1000,1000,2000) 就是表示震动1秒之后暂停1秒,再震动2秒有兴趣的,扫下这个二维码可体验http://1.aaaa.sinaapp.com/deviceDemo/Vibration.html一口气说了这么一堆,其实后面的这几个点,都还在标准化的路上,不同机型/平台支持不太一致,在实际项目中使用还是要注意点区别对待的~你们先回味着,我一个人先伤一会儿心去。【走在时代前列的腾讯HTML 5精品好文】DNF实战总结好文!《腾讯游戏实战!DNF浴火新生H5项目总结》优化HMTL 5页面的6个技巧!《腾讯精品文!六大奇招带你优化HTML5移动页面》H5页面设计实战总结!《春雨先知!腾讯移动端H5页面设计实战分享》原文地址:tgideas.qq作者:鬼爪手【优设网 原创文章 投稿邮箱:2650232288@qq.com】================关于优设网================“优设网uisdc.com“是国内人气最高的网页设计师学习平台,专注分享网页设计、无线端设计以及PS教程。【特色推荐】设计师需要读的100本书:史上最全的设计师图书导航:http://hao.uisdc.com/book/。设计微博:拥有粉丝量97万的人气微博@优秀网页设计,欢迎关注获取网页设计资源、下载顶尖设计素材。设计导航:全球顶尖设计网站推荐,设计师必备导航:http://hao.uisdc.com———————————————————–想在手机上、被窝里获取设计教程、经验分享和各种意想不到的”福利”吗?添加 优秀网页设计 微信号:【youshege】优设哥的全拼您也可以通过扫描下方二维码快速添加:相关文章春雨先知!腾讯移动端H5页面设计实战分享神器推荐!零代码制作属于你的第一个酷炫H5页面腾讯精品文!六大奇招带你优化HTML5移动页面腾讯游戏实战!DNF浴火新生H5项目总结月中福利!献给网页设计师的HTML5/CSS3/JS便捷工具超赞!20个鼓舞人心的HTML5网页游戏设计Tag优设哥向您推荐:腾讯游戏实战!DNF浴火新生H5项目总结腾讯ecd招聘【上海招聘】腾讯上海设计中心招聘实习生腾讯技术文!浅议内滚动布局的概念与实现方法如此风骚!2014年刷爆朋友圈的十大 HTML5 技术案例无觅原文地址:http://www.uisdc.com/tgideas-html5-api-test-2