Maison > développement back-end > tutoriel php > Comment envoyer simultanément des données FormData et String dans JQuery AJAX ?

Comment envoyer simultanément des données FormData et String dans JQuery AJAX ?

Patricia Arquette
Libérer: 2024-10-22 14:20:03
original
1074 Les gens l'ont consulté

How to Send FormData and String Data Simultaneously in 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>
Copier après la connexion

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>
Copier après la connexion

Explication :

  • serializeArray() : Cette méthode récupère les données du formulaire sous forme de tableau d'objets, offrant un meilleur contrôle sur le nom et la valeur de chaque entrée.
  • contentType : false et processData : false : Ces paramètres désactivent le traitement des données par défaut de JQuery et permettent d'envoyer les FormData brutes à le serveur.
  • 'submit.php' : remplacez-le par l'URL du script côté serveur qui gérera les données du fichier et de la chaîne.

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>
Copier après la connexion

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal