これを同期動作にするには、最後の転送が完了したら新しい転送を開始する必要があります。たとえば、Gmailはすべてを一度に同時に送信します。 AJAXファイルアップロードの進捗状況は、XmlHttpRequest
インスタンスのprogress
またはonprogress
です。
したがって、サーバー側(私はあなたが何を使用するのか分かりません)で、次の入力時にAJAXを実行するためのJSON応答を送信します。 1つのオプションは、AJAX要素を各要素にバインドして、簡単にすることができるので、success
の$(this).sibling('input').execute_ajax()
で行うことができます。このような
何か:
$('input[type="file"]').on('ajax', function(){
var $this = $(this);
$.ajax({
'type':'POST',
'data': (new FormData()).append('file', this.files[0]),
'contentType': false,
'processData': false,
'xhr': function() {
var xhr = $.ajaxSettings.xhr();
if(xhr.upload){
xhr.upload.addEventListener('progress', progressbar, false);
}
return xhr;
},
'success': function(){
$this.siblings('input[type="file"]:eq(0)').trigger('ajax');
$this.remove(); // remove the field so the next call won't resend the same field
}
});
}).trigger('ajax'); // Execute only the first input[multiple] AJAX, we aren't using $.each
上記のコードは、複数の<input type="file">
のためになるが、<input type="file" multiple>
ため、その場合には、それがあるべきではない:
var count = 0;
$('input[type="file"]').on('ajax', function(){
var $this = $(this);
if (typeof this.files[count] === 'undefined') { return false; }
$.ajax({
'type':'POST',
'data': (new FormData()).append('file', this.files[count]),
'contentType': false,
'processData': false,
'xhr': function() {
var xhr = $.ajaxSettings.xhr();
if(xhr.upload){
xhr.upload.addEventListener('progress', progressbar, false);
}
return xhr;
},
'success': function(){
count++;
$this.trigger('ajax');
}
});
}).trigger('ajax'); // Execute only the first input[multiple] AJAX, we aren't using $.each
このコードがのみいるFormDataとXmlHttpRequest2をサポート本当に最近のブラウザのために意図されていること、ノート、それはとてもおいしそうなぜ、古いブラウザ – pocesar
のためのハックが...不思議なかった;) – Selosindis
は新しい「フォーム」を作成し、追加します(新しいFormData())を使用してファイルを1つずつ追加します。append( 'file'、this.files [count]) 'は私が探していたものでした。 – Mark