admin管理员组文章数量:1334671
function makeCall(file, handlerFile, sendMethod, formData) {
//console.log(instance.files);
$.ajax({
url: handlerFile,
type: sendMethod,
xhr: function() { // Custom XMLHttpRequest
var xhr = $.ajaxSettings.xhr();
if(xhr.upload) { // Check if upload property exists
xhr.upload.addEventListener('progress', progressHandlingFunction.bind(file)); // For handling the progress of the upload
//xhr.upload.addEventListener('loadend', successHandler.bind(xhr));
}
//console.log(xhr);
return xhr;
},
beforeSend: beforeSendHandler.bind(file),
success: pleteHandler.bind(file),
//error: errorHandler,
data: formData, // Form data
dataType: 'json',
cache: true,
//async: false,
contentType: false,
processData: false
});
}
$(".afu-input").on('change', function() {
var i = 0;
var length = this.files.length;
var files = this.files;
var calling = setInterval(function() {
var file = files[i];
console.log(file);
uid = generateUniqueId();
file.id = uid;
var formData = null;
formData = new FormData();
formData.append(i, file);
formData.append(i, [uid]);
makeCall(file, handlerFile, sendMethod, formData);
i++;
if (i >= length) {
clearInterval(calling);
}
}, 2000); // Delay is for testing. Normaly there is no delay
}
I'm trying to upload file one by one. But the problem is that ajax sending request properly, but getting only one(first) data return.
My goal is to create script which uploads images(and later other files) on input[type=file] change. I tried to upload multiple files with one request, but progress event registering them as one. I had idea to slice(chunk) files into pieces ant send them, but this variant seems easier(just need to make it work, then I improve it). Thanks.
function makeCall(file, handlerFile, sendMethod, formData) {
//console.log(instance.files);
$.ajax({
url: handlerFile,
type: sendMethod,
xhr: function() { // Custom XMLHttpRequest
var xhr = $.ajaxSettings.xhr();
if(xhr.upload) { // Check if upload property exists
xhr.upload.addEventListener('progress', progressHandlingFunction.bind(file)); // For handling the progress of the upload
//xhr.upload.addEventListener('loadend', successHandler.bind(xhr));
}
//console.log(xhr);
return xhr;
},
beforeSend: beforeSendHandler.bind(file),
success: pleteHandler.bind(file),
//error: errorHandler,
data: formData, // Form data
dataType: 'json',
cache: true,
//async: false,
contentType: false,
processData: false
});
}
$(".afu-input").on('change', function() {
var i = 0;
var length = this.files.length;
var files = this.files;
var calling = setInterval(function() {
var file = files[i];
console.log(file);
uid = generateUniqueId();
file.id = uid;
var formData = null;
formData = new FormData();
formData.append(i, file);
formData.append(i, [uid]);
makeCall(file, handlerFile, sendMethod, formData);
i++;
if (i >= length) {
clearInterval(calling);
}
}, 2000); // Delay is for testing. Normaly there is no delay
}
I'm trying to upload file one by one. But the problem is that ajax sending request properly, but getting only one(first) data return.
My goal is to create script which uploads images(and later other files) on input[type=file] change. I tried to upload multiple files with one request, but progress event registering them as one. I had idea to slice(chunk) files into pieces ant send them, but this variant seems easier(just need to make it work, then I improve it). Thanks.
Share Improve this question edited Oct 25, 2013 at 10:03 minus1 asked Oct 24, 2013 at 16:19 minus1minus1 5911 gold badge6 silver badges15 bronze badges 2- Is there a reason for the 2 second delay between uploads? – user1091949 Commented Oct 25, 2013 at 5:02
- Nop, just for testing, I was looking for problem and added 2s delay. Yesterday I was googling a lot and found that it can be done with Deferred in jQuery I will test it soon. – minus1 Commented Oct 25, 2013 at 11:35
1 Answer
Reset to default 5It's easy to make it with jQuery.when();
Ajax calls can be any number. So you need to use it with apply(); and create array of ajax calls. Now code looks like this:
function makeCall(file, formData) {
return $.ajax({ // It's necessary to return ajax call
url: 'handler.php',
type: 'POST',
xhr: function() { // Creating custom XHR to register progress event(If you know better solution - please post ir)
var xhr = $.ajaxSettings.xhr();
if (xhr.upload) { // Check if upload property exists
xhr.upload.addEventListener('progress', progressHandlingFunction.bind(file)); // Registering progress event
}
return xhr;
},
// Events handlers
beforeSend: beforeSendHandler.bind(file),
success: pleteHandler,
data: formData,
dataType: 'json',
cache: true,
contentType: false,
proccessData: false
});
}
$('.afu-input').on('change', function() {
var files = this.files;
var calls = [];
$.each(files, function(i, file) {
uid = generateUniqueId();
file.id = uid;
var formData = new formData();
formData.append(0, file); // Just easier to set index to 0 cause for every file returning new obejct, so is no point to set more indexes
calls.push(makeCall(file, formData)); // And finally pushing calls to array
});
// Using jQuery.when
// Cause I don't know how many calls will be I'm using "apply" so I can add array instead of one by one calls
$.when.apply($, calls); // Exactly I don't know why need "$"
}
function beforeSendHandler() {
console.log(this);
}
function pleteHandler(data) {
console.log(data);
}
function progressHandlingFunction(e) {
console.log(e);
console.log(this);
}
本文标签: javascriptjQuery multiple AJAX requests at same timeStack Overflow
版权声明:本文标题:Javascript, jQuery multiple AJAX requests at same time - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1742378140a2463577.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论