Maison interface Web Voir.js Un guide complet pour implémenter le téléchargement de fichiers dans Vue (axios, element-ui)

Un guide complet pour implémenter le téléchargement de fichiers dans Vue (axios, element-ui)

Jun 09, 2023 pm 04:12 PM
vue axios element-ui

Guide complet d'implémentation du téléchargement de fichiers dans Vue (axios, element-ui)

Dans les applications Web modernes, le téléchargement de fichiers est devenu une fonction de base. Qu'il s'agisse de télécharger des avatars, des images, des documents ou des vidéos, nous avons besoin d'un moyen fiable pour télécharger des fichiers depuis l'ordinateur de l'utilisateur vers le serveur.

Cet article vous fournira un guide détaillé sur la façon d'utiliser Vue, axios et element-ui pour implémenter le téléchargement de fichiers.

  1. Qu'est-ce qu'axios

axios est un client HTTP basé sur des promesses pour les navigateurs et node.js. Il prend en charge tous les navigateurs modernes ainsi que IE8 et supérieur. De plus, axios gère avec élégance de nombreuses requêtes XHR courantes et de nombreux détails de l'API. Nous pouvons facilement implémenter notre fonctionnalité de téléchargement de fichiers en utilisant axios.

  1. Créez une page et un formulaire de base avec element-ui

Tout d'abord, créons une page et un formulaire de base. Nous utiliserons element-ui pour créer un formulaire simple et collecter les fichiers téléchargés par les utilisateurs.

<template>
  <div class="upload-form">
    <el-upload :action="serverUrl" :on-success="uploadSuccess" :headers="headers"
               :before-upload="beforeUpload" :on-error="uploadError">
      <el-button size="small" type="primary">点击上传</el-button>
      <div slot="tip" class="upload-tip">只能上传jpg/png文件,且不超过2MB</div>
    </el-upload>
  </div>
</template>

<script>
export default {
  data () {
    return {
      serverUrl: '/api/upload',
      headers: {
        'Content-Type': 'multipart/form-data'
      }
    }
  },
  methods: {
    beforeUpload (file) {
      const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'
      const isLt2M = file.size / 1024 / 1024 < 2

      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG/PNG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      return isJPG && isLt2M
    },
    uploadSuccess (response) {
      console.log(response.data)
      this.$message.success('头像上传成功!')
    },
    uploadError (error) {
      console.log(error)
      this.$message.error('上传头像图片失败!')
    }
  }
}
</script>

<style scoped>
.upload-form {
  margin-top: 20px;
  text-align: center;
}
.upload-tip {
  margin-top: 10px;
  color: #999;
}
</style>

Ici, nous utilisons le composant de téléchargement d'element-ui pour définir certains paramètres et événements liés au téléchargement. Lorsque l'utilisateur sélectionne le fichier et clique sur le bouton de téléchargement, nous effectuerons les opérations suivantes :

  • Avant le téléchargement, nous vérifierons le type et la taille du fichier de l'image à partir de l'objet fichier transmis , sinon Si les conditions sont remplies, le téléchargement sera bloqué et un message d'erreur sera affiché à l'utilisateur ;
  • Lorsque le téléchargement est réussi, nous afficherons les données de réponse et enverrons un téléchargement réussi ; message à l'utilisateur ;
  • in Lorsqu'une erreur de téléchargement se produit, nous afficherons l'erreur et enverrons un message d'erreur à l'utilisateur.
  1. Composant Vue qui implémente le téléchargement de fichiers

Maintenant, nous avons créé un formulaire simple pour collecter les fichiers téléchargés par les utilisateurs, nous devez télécharger le fichier sur le serveur. Nous utiliserons axios pour cette tâche.

<template>
  <!-- 这里插入上一部分的代码 -->
</template>

<script>
import axios from 'axios'

export default {
  data () {
    return {
      serverUrl: '/api/upload',
      headers: {
        'Content-Type': 'multipart/form-data'
      }
    }
  },
  methods: {
    beforeUpload (file) {
      const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'
      const isLt2M = file.size / 1024 / 1024 < 2

      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG/PNG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      return isJPG && isLt2M
    },
    uploadSuccess (response) {
      console.log(response.data)
      this.$message.success('头像上传成功!')
    },
    uploadError (error) {
      console.log(error)
      this.$message.error('上传头像图片失败!')
    },
    uploadFile (file) {
      const formdata = new FormData()
      formdata.append('file', file)
      axios.post(this.serverUrl, formdata, {
        headers: this.headers
      }).then((response) => {
        this.uploadSuccess(response)
      }).catch((error) => {
        this.uploadError(error)
      })
    }
  }
}
</script>

<style scoped>
  <!-- 这里插入上一部分的代码 -->
</style>

Dans le code ci-dessus, nous avons introduit axios, puis nous avons défini la méthode uploadFile pour télécharger des fichiers. Dans cette méthode, nous créons d'abord une instance FormData pour envoyer le fichier au serveur avec la requête. Ensuite, nous appelons la méthode axios.post pour télécharger le fichier sur le serveur. Lorsque la réponse est réussie ou échouée, nous appellerons la fonction de réponse correspondante pour envoyer un message de réussite ou d'erreur à l'utilisateur.

  1. Utilisation du composant de téléchargement de fichiers dans l'application Vue

Maintenant que nous avons créé un composant avec une fonctionnalité de téléchargement, nous allons l'intégrer dans Vue dans le application.

<template>
  <div>
    <NavigationBar /> <!-- 插入导航栏组件代码 -->
    <UploadForm /> <!-- 插入上传表单组件代码 -->
  </div>
</template>

<script>
import NavigationBar from './components/NavigationBar.vue'
import UploadForm from './components/UploadForm.vue'

export default {
  components: {
    NavigationBar,
    UploadForm
  }
}
</script>

Ici, nous introduisons deux composants, NavigationBar et UploadForm, et les plaçons dans le modèle du composant principal de Vue.

  1. Backend Server

Enfin, nous avons besoin d'un serveur backend pour accepter les fichiers téléchargés et les enregistrer sur le serveur. Vous trouverez ci-dessous un exemple simple de serveur Express.

const express = require('express')
const bodyParser = require('body-parser')
const multer  = require('multer')
const app = express()

const upload = multer({ dest: 'uploads/' })

app.use(bodyParser.json())
app.use(bodyParser.urlencoded())

app.post('/api/upload', upload.single('file'), (req, res) => {
  console.log(req.file)
  res.status(200).json({
    success: true,
    message: 'File uploaded successfully!'
  })
})

app.listen(3000, () => {
  console.log('Server listening on port 3000')
})

Dans ce serveur Express, nous utilisons le middleware multer pour analyser les fichiers téléchargés et les enregistrer dans le dossier de téléchargement. Nous publions ensuite les informations du fichier téléchargé dans le gestionnaire de route et envoyons une réponse positive au client. Vous pouvez télécharger des fichiers en fonction de vos besoins réels.

Summary

Dans cet article, nous avons exploré comment utiliser Vue, axios et element-ui pour créer une application Web avec une fonctionnalité de téléchargement de fichiers. Nous avons appris à utiliser le composant de téléchargement element-ui pour collecter les fichiers téléchargés par les utilisateurs et à utiliser axios pour télécharger les fichiers sur le serveur via HTTP. Dans le même temps, nous avons également appris à créer un serveur Express pour accepter et analyser les fichiers téléchargés.

Ceci est un guide détaillé et complet pour vous aider à implémenter la fonctionnalité de téléchargement de fichiers dans votre application Vue. Si vous avez des questions ou des idées, laissez-les dans les commentaires !

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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Porce de variable PHP expliquée
1 Il y a quelques mois By 百草
Commentant le code en php
4 Il y a quelques semaines By 百草
<🎜>: Grow A Garden - Guide complet des marchands itinérants
3 Il y a quelques semaines By Jack chen
Conseils pour écrire des commentaires PHP
4 Il y a quelques semaines By 百草

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1510
276
Quelle est la signification de la transformation de la réactivité de Vue (expérimentale, puis supprimée) et de ses objectifs? Quelle est la signification de la transformation de la réactivité de Vue (expérimentale, puis supprimée) et de ses objectifs? Jun 20, 2025 am 01:01 AM

ReactivitytransforminVue3aimedtosimplifyhandlingreactivedatabyautomaticallytrackingandmanagingreactivitywithoutrequiringmanualref()or.valueusage.Itsoughttoreduceboilerplateandimprovecodereadabilitybytreatingvariableslikeletandconstasautomaticallyreac

Comment l'internationalisation (I18N) et la localisation (L10N) peuvent-elles être mises en œuvre dans une application VUE? Comment l'internationalisation (I18N) et la localisation (L10N) peuvent-elles être mises en œuvre dans une application VUE? Jun 20, 2025 am 01:00 AM

Internationalisation et olocalisation dans la variation des acquis

Qu'est-ce que le côté serveur Rendre SSR dans Vue? Qu'est-ce que le côté serveur Rendre SSR dans Vue? Jun 25, 2025 am 12:49 AM

Server-sideredering (SSR) invueImproveSperformanceAndSeoBygeneratingHtmlONTheServer.1.TheServerrunsvueAppcodeandGenerateshtmlBaseDonthecurrentRoute.2.ThathtmLissentToHebroweToWeTerterActive.

Comment construire une bibliothèque de composants avec Vue? Comment construire une bibliothèque de composants avec Vue? Jul 10, 2025 pm 12:14 PM

La construction d'une bibliothèque de composants Vue nécessite la conception de la structure autour du scénario d'entreprise et le suivi du processus complet de développement, de test et de libération. 1. La conception structurelle doit être classée en fonction des modules fonctionnels, y compris des composants de base, des composants de mise en page et des composants commerciaux; 2. Utilisez des variables SCSS ou CSS pour unifier le thème et le style; 3. Unifier les spécifications de dénomination et introduire Eslint et plus joli pour assurer le style de code cohérent; 4. Afficher l'utilisation des composants sur le site de document de support; 5. Utilisez VITE et d'autres outils pour emballer en tant que packages NPM et configurer les rolupoptions; 6. Suivez la spécification SEMVER pour gérer les versions et les modifications modifiées lors de la publication.

Comment implémenter les transitions et les animations dans Vue? Comment implémenter les transitions et les animations dans Vue? Jun 24, 2025 pm 02:17 PM

ToaddtransitionsandanimationsInvue, usebuilt-incomponentslikeandand, applatcsclasses, leveragetransitionhooksforControl, andoptimezeperformance.1.wrapelementswithandapplycsstransitionclasses lisev-enter-actinterforbasicfadeorslideeffets.2.

Quel est le but de la fonction NextTick à Vue, et quand est-elle nécessaire? Quel est le but de la fonction NextTick à Vue, et quand est-elle nécessaire? Jun 19, 2025 am 12:58 AM

NextTick est utilisé dans Vue pour exécuter du code après la mise à jour DOM. Lorsque les données changent, Vue ne mettra pas à jour le DOM immédiatement, mais le mettra dans la file d'attente et le traitera dans la prochaine boucle d'événement "Tick". Par conséquent, si vous devez accéder ou exploiter le DOM mis à jour, NextTick doit être utilisé; Les scénarios courants incluent: l'accès au contenu DOM mis à jour, la collaboration avec des bibliothèques tierces qui s'appuient sur l'état DOM et le calcul en fonction de la taille de l'élément; Son utilisation comprend l'appel. $ NextTick comme méthode de composant, l'utiliser seul après l'importation et la combinaison asynchrone / attendre; Les précautions comprennent: éviter une utilisation excessive, dans la plupart des cas, aucun déclenchement manuel n'est requis, et un prochain peut capturer plusieurs mises à jour à la fois.

Comment utiliser PHP pour développer une plate-forme communautaire Q&A explication détaillée du modèle de monétisation communautaire interactive PHP Comment utiliser PHP pour développer une plate-forme communautaire Q&A explication détaillée du modèle de monétisation communautaire interactive PHP Jul 23, 2025 pm 07:21 PM

1. Le premier choix pour la combinaison Laravel Mysql Vue / React dans la communauté de questions et réponses de développement PHP est le premier choix pour la combinaison Laravel Mysql Vue / React, en raison de sa maturité dans l'écosystème et de l'efficacité de développement élevée; 2. Les performances élevées nécessitent une dépendance à la cache (redis), une optimisation de la base de données, des files d'attente CDN et asynchrones; 3. La sécurité doit être effectuée avec le filtrage d'entrée, la protection CSRF, les HTTP, le cryptage de mot de passe et le contrôle d'autorisation; 4. Publicité facultative, abonnement aux membres, récompenses, commissions, paiement des connaissances et autres modèles, le noyau est de faire correspondre le ton communautaire et les besoins des utilisateurs.

Comment développer un système de forme intelligente AI avec PHP PHP PHP Intelligent Form Design and Analysis Comment développer un système de forme intelligente AI avec PHP PHP PHP Intelligent Form Design and Analysis Jul 25, 2025 pm 05:54 PM

Lorsque vous choisissez un cadre PHP approprié, vous devez considérer de manière approfondie en fonction des besoins du projet: Laravel convient au développement rapide et fournit des moteurs de modèle éloquente et de lame, qui sont pratiques pour le fonctionnement de la base de données et le rendu de formulaire dynamique; Symfony est plus flexible et adapté aux systèmes complexes; Codeigniter est léger et adapté à des applications simples avec des exigences de performance élevées. 2. Pour assurer la précision des modèles d'IA, nous devons commencer avec une formation de données de haute qualité, une sélection raisonnable des indicateurs d'évaluation (tels que la précision, le rappel, la valeur F1), l'évaluation régulière des performances et le réglage du modèle, et assurer la qualité du code grâce aux tests unitaires et aux tests d'intégration, tout en surveillant continuellement les données d'entrée pour empêcher la dérive des données. 3. De nombreuses mesures sont nécessaires pour protéger la confidentialité des utilisateurs: crypter et stocker des données sensibles (comme AES

See all articles