github.com/insionng/yougam@v0.0.0-20170714101924-2bc18d833463/themes/wind/static/libs/sockjs-client-1.1.0/tests/html/web-worker.html (about) 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="X-UA-Compatible" content="IE=edge" /> 5 <meta charset="UTF-8" /> 6 7 <link href="" rel="icon" type="image/x-icon" /> 8 9 <script type="text/javascript" src="lib/sockjs.js"></script> 10 <script type="text/javascript" src="static/jquery.min.js"></script> 11 12 <script type="text/javascript" src="config.js"></script> 13 </head> 14 <body> 15 <form> 16 <select id="transport"> 17 <option value="">- any - </option> 18 <option value="websocket">websocket</option> 19 <option value="xdr-streaming">xdr-streaming</option> 20 <option value="xhr-streaming">xhr-streaming</option> 21 <option value="eventsource">eventsource</option> 22 <option value="iframe-eventsource">iframe-eventsource</option> 23 <option value="htmlfile">htmlfile</option> 24 <option value="iframe-htmlfile">iframe-htmlfile</option> 25 <option value="xdr-polling">xdr-polling</option> 26 <option value="xhr-polling">xhr-polling</option> 27 <option value="iframe-xhr-polling">iframe-xhr-polling</option> 28 <option value="jsonp-polling">jsonp-polling</option> 29 </select> 30 <input type="checkbox" id="sameOrigin" checked>Same Origin? 31 <input type="button" value="Connect" id="connect"> 32 <input type="button" value="Disconnect" id="disconnect" disabled="yes"> 33 </form> 34 35 Latency: <code id="latency"></code><br> 36 <code id="logs" style="height:200px; overflow:auto; display: block; border: 1px gray solid;"> 37 </code> 38 39 <script> 40 /* global $, clientOptions */ 41 'use strict'; 42 function log(a) { 43 if ('console' in window && 'log' in window.console) { 44 console.log(a); 45 } 46 $('#logs').append($('<code>').text(a)); 47 $('#logs').append($('<br>')); 48 $('#logs').scrollTop($('#logs').scrollTop() + 10000); 49 } 50 51 var worker; 52 function send() { 53 worker.postMessage(JSON.stringify({ type: 'message', data: JSON.stringify({ t: (new Date()).getTime()}) })); 54 } 55 function onopen() { 56 log('connected'); 57 $('#sameOrigin').attr('disabled', true); 58 send(); 59 } 60 function onclose(code, reason) { 61 log('disconnected ' + code + ', ' + reason); 62 $('#connect').each(function(_,e){ 63 e.disabled = ''; 64 }); 65 $('#disconnect').attr('disabled', true); 66 $('#sameOrigin').attr('disabled', false); 67 } 68 69 var i = 0; 70 function xonmessage(e) { 71 var msg = JSON.parse(e); 72 var td = (new Date()).getTime() - msg.t; 73 $('#latency').text('' + i + ' ' + td + ' ms'); 74 i += 1; 75 send(); 76 } 77 78 $('#connect').click(function() { 79 $('#connect').attr('disabled', true); 80 $('#disconnect').each(function(_,e){ 81 e.disabled = ''; 82 }); 83 var transport = $('#transport').val() || undefined; 84 log('[connecting] ' + transport); 85 var url; 86 if ($('#sameOrigin').prop('checked')) { 87 if (window.location.origin) { 88 url = window.location.origin; 89 } else { 90 url = window.location.protocol + '//' + window.location.hostname + 91 (window.location.port ? ':' + window.location.port : ''); 92 } 93 } else { 94 url = clientOptions.url; 95 } 96 worker = new Worker('lib/worker.js'); 97 worker.onmessage = function (e) { 98 var msg = JSON.parse(e.data); 99 switch (msg.type) { 100 case 'message': 101 xonmessage(msg.data); 102 break; 103 case 'open': 104 onopen(); 105 break; 106 case 'close': 107 onclose(msg.code, msg.reason); 108 break; 109 case 'error': 110 console.error(msg.data); 111 break; 112 default: 113 console.error('unknown type: ' + msg.type); 114 } 115 }; 116 117 worker.postMessage(JSON.stringify({ type: 'open', url: url + '/echo', transports: transport })); 118 }); 119 $('#disconnect').click(function() { 120 $('#disconnect').attr('disabled', true); 121 log('[disconnecting]'); 122 worker.postMessage(JSON.stringify({ type: 'close' })); 123 }); 124 </script> 125 </body> 126 </html>