JS: Как отправить несколько файлов с использованием FormData(jQuery Ajax)
В моей форме есть несколько загрузок файлов, используя FormData
загружается только один файл, хотя я выбираю более одного файла для загрузки, следующий код
HTML
<form name="uploadImages" method="post" enctype="multipart/form-data">
<input type="file" name="photo[]" value="">
<input type="file" name="photo[]" value="">
<input type="file" name="photo[]" value="">
</form>
JS
var ajaxData = new FormData();
ajaxData.append( 'action','uploadImages');
jQuery.each($("input[name^='photo']")[0].files, function(i, file) {
ajaxData.append('photo['+i+']', file);
});
$.ajax({
url: URL,
data: ajaxData,
cache: false,
contentType: false,
processData: false,
type: 'POST',
dataType:'json',
success: function(data) {
if (data.status == 'success') {
location.reload();
}
}
});
я использую PHP
на сервере, используя HTML attribute name
я, е photo
только я могу сохранять файлы, динамические имена файлов не будут работать для меня.
4 ответа
Решение
У вас есть ошибка в JavaScript: вы перебираете только файлы в одном входе, пожалуйста, посмотрите на это
var ajaxData = new FormData();
ajaxData.append( 'action','uploadImages');
$.each($("input[type=file]"), function(i, obj) {
$.each(obj.files,function(j, file){
ajaxData.append('photo['+j+']', file);
})
});
пример на jsfiddle
В передней части
<form name="uploadImages" method="post" enctype="multipart/form-data">
<input type="file" name="photo[]" value=""/>
<input type="file" name="photo[]" value=""/>
<input type="file" name="photo[]" value=""/>
<button id="btn">btn</button>
</form>
<script>
$(function(){
var ajaxData = new FormData();
ajaxData.append( 'action','uploadImages');
$.each($("input[type=file]"), function(i, obj) {
$.each(obj.files,function(j, file){
ajaxData.append('photo['+j+']', file);
$('#btn').on('click',function(){
$.ajax({
url:'https://stores-govan.c9users.io/test',
type:"POST",
data:ajaxData,
processData:false,
contentType:false,
success:function(){
},
crossDomain:true
})
})
})
});
})
</script>
в бэкэнде (nodejs) добавьте это (используя multer)
var multer=require('multer')
app.post('/test',upload.array('photo[]',6),function(req ,res,next){
var images=[]
if(req.files){
for(var i=0;i<req.files.length;i++){
images[i]=req.files[i].filename }
}
console.log(images)
})
<input type="file" name="Attachment[]" class="form-control TheFiles" />
Предыдущий ответ содержит небольшую ошибку, которая была исправлена в следующем коде, и он будет работать для отправки нескольких файлов через ajax:
var formData = new FormData();
$.each($(".TheFiles"), function (i, obj) {
$.each(obj.files, function (j, file) {
formData.append('Attachment[' + i + ']', file); // is the var i against the var j, because the i is incremental the j is ever 0
});
});
formData.append('Destination', Destination); //add more variables that you need
formData.append('ReplyTo', ReplyTo);//add more variables that you need
formData.append('Body', Body);//add more variables that you need
опционально только для просмотра моего конфига ajax
$.ajax({
url: 'YourUrl',
type: 'POST',
data: formData,
async: false,
success: function (data) {
location.reload();
},
complete: function () {
$(Here).text('Enviado com sucesso');
},
error: function (err) {
alert("Não deixe nenhum campo vazio");
},
cache: false,
contentType: false,
processData: false
});
Это отлично работает:
var data = new FormData();
for( var i = 0, len = document.getElementById('attachment').files.length; i < len; i++ ){
data.append( "files" + i, document.getElementById('attachment').files[i] );
}
Эти ответы не работают.
var ajaxData = new FormData();
ajaxData.append( 'action','uploadImages');
$.each($("input[type=file]"), function(i, obj) {
$.each(obj.files,function(j,file){
ajaxData.append('photo['+j+']', file);//i had to change "i" by "j"
})
});