I want to create a game-like ping in Javascript, just like the game Counter Strike for example. I\'m doing an AJAX call to the server (MySQL) and want to calculate the time that
the lower response time is because by default the cache
property is set to true, set it to false
so that every time it goes to the server not the cache
var ping = new Date;
$.ajax({ type: "POST",
url: "server.php",
data: {....},
cache:false,
success: function(output){
ping = new Date - ping;
}
});
You will not be able to calculate accurate latency on client side (not counting java, flash or websockets), you need the server to calculate it and return the value in a response. Getting anything other than 0ms
for localhost should be enough evidence of this :P
The earliest time in connection state gets me 300ms
for stackoverflow.com
, while the real number is closer to 100ms
.
var a = new XMLHttpRequest();
a.onreadystatechange = function () {
if (a.readyState === a.HEADERS_RECEIVED) {
a.abort();
console.log(new Date - abc);
}
};
var abc = new Date;
a.open("GET", "/");
a.send(null);
Waiting for the full response (a.DONE
) took 949ms