Maison > développement back-end > tutoriel php > Comment envoyer simultanément des données FormData et String à l'aide de JQuery AJAX

Comment envoyer simultanément des données FormData et String à l'aide de JQuery AJAX

DDD
Libérer: 2024-10-22 15:16:02
original
956 Les gens l'ont consulté

How to Send FormData and String Data Simultaneously Using JQuery AJAX

Envoi simultané de données de formulaire et de données de chaîne via JQuery AJAX

La transmission des données de fichier et des données de chaîne d'entrée régulière via une seule requête AJAX peut être réalisée avec FormData(). Par exemple, vous pouvez avoir plusieurs champs de saisie masqués que vous souhaitez inclure dans la requête du serveur à côté des données du fichier.

Considérez le formulaire HTML suivant :

<code class="html"><form action="image.php" method="post" enctype="multipart/form-data">
<input type="file" name="file[]" multiple="" />
<input type="hidden" name="page_id" value="<?php echo $page_id; ?>"/>
<input type="hidden" name="category_id" value="<?php echo $item_category->category_id; ?>"/>
<input type="hidden" name="method" value="upload"/>
<input type="hidden" name="required[category_id]" value="Category ID"/>
</form></code>
Copier après la connexion

Utilisation du code JQuery suivant , cependant, seules les données du fichier sont envoyées, en laissant de côté les données d'entrée masquées :

<code class="jquery">// HTML5 form data object.
var fd = new FormData();

var file_data = object.get(0).files[i];
var other_data = $('form').serialize(); // page_id=&amp;category_id=15&amp;method=upload&amp;required%5Bcategory_id%5D=Category+ID

fd.append("file", file_data);

$.ajax({
    url: 'add.php',
    data: fd,
    contentType: false,
    processData: false,
    type: 'POST',
    success: function(data){
        alert(data);
    }
});</code>
Copier après la connexion

La clé pour inclure à la fois les données de fichier et de chaîne dans FormData() réside dans la modification du code JQuery comme suit :

<code class="javascript">var fd = new FormData();
var file_data = $('input[type="file"]')[0].files; // for multiple files
for(var i = 0;i<file_data.length;i++){
    fd.append("file_"+i, file_data[i]);
}
var other_data = $('form').serializeArray();
$.each(other_data,function(key,input){
    fd.append(input.name,input.value);
});
 $.ajax({
    url: 'test.php',
    data: fd,
    contentType: false,
    processData: false,
    type: 'POST',
    success: function(data){
        console.log(data);
    }
});</code>
Copier après la connexion

Les modifications ont introduit une boucle for qui gère plusieurs entrées de fichiers et modifie .serialize() en .serializeArray() pour obtenir un tableau d'objets à manipuler dans une boucle .each(), où les données peuvent être ajouté à FormData().

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal