I need to get the % completion for ajax request.
I tried the following:
$(document).ready(function() {
$.ajax({
xhr : function() {
var xhr = new window.XMLHttpRequest();
xhr.upload.addEventListener("progress", function(evt) {
if (evt.lengthComputable) {
var percentComplete = (evt.loaded / evt.total) * 100;
//Do something with upload progress here
}
}, false);
xhr.addEventListener("progress", function(evt) {
if (evt.lengthComputable) {
var percentComplete = (evt.loaded / evt.total) * 100;
//Do something with download progress
console.log(percentComplete);
}
}, false);
return xhr;
},
url : my_path
}).done(function(data) {
console.log(data);
});
});
The problem is how do I check whether the above code is working or not. I always get 100
in the firebug console, I doubt instead of 100
there should be multiple %
entries in console.
my_path
is a PHP page that returns records from MySQL DB. Is there any way to slow down the process/page rendering to check the functionality?
The problem with using DB reads is the size needs to be known first, so you really need a file to test this.
For Downloading (client downloading off from the server), you need to introduce delay, otherwise you're only recourse is to download a huge file.
Try this script, which sets up the correct content length headers and only outputs 50 bytes at a time, with a 1 second delay (you can test it with a relatively small file, woot).
As for Uploading (posting to the server), your only option in this regard is to make it a big file, and discard it when done.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With