Dans mon formulaire, plusieurs fichiers sont téléchargés, en utilisant FormData
, un seul fichier est en cours de téléchargement, bien que je sélectionne plus d'un fichier à télécharger, voici le code
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();
}
}
});
J'utilise PHP
sur le serveur, en utilisant HTML attribute name
i, e photo
seulement, mais je suis capable de sauvegarder des fichiers. Les noms de fichiers dynamiques ne fonctionneront pas pour moi.
Vous avez une erreur en javascript: vous ne parcourez que les fichiers d'une entrée, jetez un coup d'œil à ceci
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);
})
});
exemple sur jsfiddle
<input type="file" name="Attachment[]" class="form-control TheFiles" />
La réponse précédente a une petite erreur qui a été corrigée sur le code suivant, et cela va fonctionner pour envoyer plusieurs fichiers via 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
éventuellement juste pour vous pouvez voir ma config 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
});
devant
<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>
au niveau du serveur (nodejs), ajoutez ceci (en utilisant 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)
})
Ces réponses ne fonctionnent pas.
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"
})
});