Maison > interface Web > js tutoriel > Comment implémenter le téléchargement de fichiers AJAX avec FormData par glisser-déposer ?

Comment implémenter le téléchargement de fichiers AJAX avec FormData par glisser-déposer ?

Barbara Streisand
Libérer: 2024-12-18 20:37:11
original
653 Les gens l'ont consulté

How to Implement AJAX File Upload with FormData Using Drag and Drop?

Téléchargement de fichiers AJAX avec FormData

Problème :

Utilisation de FormData pour le téléchargement de fichiers dans un Requête AJAX avec HTML dynamique généré par glisser-déposer fonctionnalité.

Code HTML :

<form>
Copier après la connexion

Code JavaScript :

$('.wpc_contact').submit(function(event) {
  var form = $('.wpc_contact').serialize();
  var formname = $('.wpc_contact').attr('name');
  var FormData = new FormData($(form)[1]);

  $.ajax({
    url: '<?php echo plugins_url(); ?>/wpc-contact-form/resources/js/tinymce.php',
    data: { form: form, formname: formname, FormData: FormData },
    type: 'POST',
    processData: false,
    contentType: false,
    success: function(data) {
      alert(data);
    }
  });
});
Copier après la connexion

Solution :

Pour utiliser correctement FormData, suivez ces étapes :

1. Préparation :

  • Utilisez l'objet JavaScript standard 'form' pour transmettre l'intégralité du formulaire à FormData() :

    var form = $('form')[0];
    var formData = new FormData(form);
    Copier après la connexion
  • Vous pouvez également spécifier des données spécifiques à FormData() :

    var formData = new FormData();
    formData.append('file', $('input[type=file]')[0].files[0]);
    Copier après la connexion

2. Envoi du formulaire :

Utilisez la requête jQuery AJAX avec ces options :

$.ajax({
  url: 'Your url here',
  data: formData,
  type: 'POST',
  contentType: false, // Required
  processData: false, // Required
  // ... Other options like success, etc.
});
Copier après la connexion

Remarque :

  • Tapez "POST " dans les options est nécessaire car tous les fichiers doivent être envoyés via une requête POST.
  • contentType : false n'est disponible que dans jQuery version 1.6 et versions ultérieures.

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.cn
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