Maison >développement back-end >tutoriel php >Comment envoyer simultanément des données FormData et String dans JQuery AJAX ?
Envoi simultané de données de formulaire et de données de chaîne dans JQuery AJAX
Lorsque vous travaillez avec des formulaires impliquant des téléchargements de fichiers, il est nécessaire de combiner les données de fichier avec des données de chaîne à soumettre au serveur. Voici comment y parvenir en utilisant FormData() dans JQuery AJAX :
Créer le FormData avec des données de fichier et de chaîne :
<code class="javascript">// Create a new FormData object var fd = new FormData(); // Append file data for (var i = 0; i < file_data.length; i++) { fd.append("file_" + i, file_data[i]); } // Append other string data using serializeArray() var other_data = $('form').serializeArray(); $.each(other_data, function (key, input) { fd.append(input.name, input.value); });</code>
Soumettre les données à l'aide AJAX :
<code class="javascript">$.ajax({ url: 'submit.php', data: fd, contentType: false, processData: false, type: 'POST', success: function (data) { console.log(data); }, });</code>
Explication :
Considérations côté serveur :
Pour récupérer les données de fichier et de chaîne sur le serveur, vous pouvez utiliser le code suivant :
<code class="php">// Files print_r($_FILES); // Other data print_r($_POST);</code>
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!