Maison >interface Web >js tutoriel >Comment implémenter les téléchargements de fichiers avec JavaScript ?

Comment implémenter les téléchargements de fichiers avec JavaScript ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-12 17:30:02835parcourir

How to Implement File Uploads with JavaScript?

Téléchargement de fichiers JavaScript

Le téléchargement de fichiers à l'aide de JavaScript nécessite une séquence d'étapes pour capturer le fichier sélectionné, rédiger la demande et gérer les notifications.

Capturer le fichier

Lorsqu'un utilisateur clique sur le bouton de saisie du fichier, le navigateur lui permet de sélectionner un fichier via une boîte de dialogue "Fichier ouvert...". Le nom du fichier sélectionné est stocké dans :

document.getElementById("image-file").value

Création de la requête

Pour envoyer le fichier à un serveur, nous utilisons une requête POST en plusieurs parties. Une manière courante de créer une telle requête consiste à utiliser l'API FormData :

let formData = new FormData();
formData.append("photo", photo);

Envoi de la requête

L'API fetch permet le téléchargement de fichiers asynchrone :

fetch('/upload/image', {method: "POST", body: formData});

Écoute des notifications

Pour écouter la fin du téléchargement, plusieurs approches peuvent être utilisé :

  1. Événements de progression XHR : Utilisez l'objet XMLHttpRequest pour suivre la progression et l'achèvement du téléchargement.
  2. Lecteur de fichiers avec événements personnalisés : Lisez le contenu du fichier à l'aide de FileReader et envoyez des événements personnalisés pour la progression et achèvement.
  3. Bibliothèques : Tirez parti des bibliothèques JavaScript comme Axios ou Multer, qui simplifient le téléchargement de fichiers et fournissent des capacités intégrées de gestion de la progression.

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!

Déclaration:
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