Last active
April 17, 2024 10:59
-
Star
(101)
You must be signed in to star a gist -
Fork
(33)
You must be signed in to fork a gist
-
-
Save jasdeepkhalsa/4353139 to your computer and use it in GitHub Desktop.
Simple Long Polling Example with JavaScript and jQuery by Tian Davis (@tiandavis) from Techoctave.com (http://techoctave.com/c7/posts/60-simple-long-polling-example-with-javascript-and-jquery)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Long Polling (Recommened Technique - Creates An Open Connection To Server ∴ Fast) | |
(function poll(){ | |
$.ajax({ url: "server", success: function(data){ | |
//Update your dashboard gauge | |
salesGauge.setValue(data.value); | |
}, dataType: "json", complete: poll, timeout: 30000 }); | |
})(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The setTimeout Technique (Not Recommended - No Queues But New AJAX Request Each Time ∴ Slow) | |
(function poll(){ | |
setTimeout(function(){ | |
$.ajax({ url: "server", success: function(data){ | |
//Update your dashboard gauge | |
salesGauge.setValue(data.value); | |
//Setup the next poll recursively | |
poll(); | |
}, dataType: "json"}); | |
}, 30000); | |
})(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The setInterval Technique (Not Recommended - Creates Queues of Requests ∴ Can Be Slow) | |
setInterval(function(){ | |
$.ajax({ url: "server", success: function(data){ | |
//Update your dashboard gauge | |
salesGauge.setValue(data.value); | |
}, dataType: "json"}); | |
}, 30000); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
No it doesn't take 30 seconds to fire the first time. It fires when the server says the connection is complete, which it will do when it notices the gauge value has changed on the server-side. At which point the client will immediately send another request, again waiting up to 30 seconds for a complete response from the server. The server doesn't necessarily respond to the requests immediately. It responds to them when the server-side logic dictates. So, the server is actually waiting to do something for the client, and the client is waiting for this to happen. That's why you usually need special servers, because many servers are not designed with this use case in mind, and even those that are probably got that way as a side effect of trying to scale through asynchronous i/o.