Web Sockets 目前在各个浏览器到终端支持性并不好, 只有IE 10+, FF 34+, Chrome 31+, Safari 7.1+, Android Browser 4.4+ 才得到支持。8 G5 Q+ x4 c6 o
. c2 q: K+ I/ K+ V通过何种方式检测?比较简单到方式是直接判断全局对象中是否包含WebSocket对象即可: - $(document).ready(function() {
5 C6 e5 _' s1 F* j6 ` - if( typeof(WebSocket) != "function" ) {% u! q3 {3 {: _, G& z$ D
- $('body').html("<h1>Error</h1><p>Your browser does not support HTML5 Web Sockets. Try Google Chrome instead.</p>");
+ R: k: q% `6 r4 D$ e( r - }2 Y G' L6 T7 y9 f0 D3 @2 R2 R- e) {, \
- })3 {4 I9 o0 Q3 c; n
复制代码
/ y9 B+ p: n6 \但是这种方法存在局限性。 在 Android 中,即使浏览器不支持 WebSocket ,但是它还是存在这个属性。
所以比较严谨的方式是: - if (typeof WebSocket != 'undefined') {
9 o' P: @7 A6 _* z/ Q( g - /*supported*/ & x+ W, Q D6 q8 Q5 l4 `5 t% a* ^
- }* N/ u7 ?- a. b5 I
+ D, s8 [1 S1 o* B+ @5 u1 q- //or
5 V2 k6 {* D5 i% { [7 P# x - if (!!window.WebSocket && window.WebSocket.prototype.send) {) n- G' T3 \8 A G; {& Q) Q
- /*supported*/: O6 [( ?6 | Y5 Q5 q# f
- }
复制代码 4 ] e& B8 m# o9 ~1 ]
|