vue实现多文件上传

本文通过实例展示了在Vue项目中如何利用ElementUI的Upload组件进行多文件上传,包括上传完成后的效果展示及关键代码实现,重点在于根据文件状态区分已上传和待上传文件。
摘要由CSDN通过智能技术生成

在vue项目中使用elementui 的 upload 上传组件,完成多个文件一次上传

一、效果图:

1.选择上传的文件:
待上传文件
2、上传完成:
已上传文件
3、删除文件:
待删除文件

二、主要的代码实现

注意处理列表中已上传文件何待上传文件,两者其实有区分的标志。我们可以在控制台中输出选择上传的文件列表,查看每个文件的代码信息,观察可以发现,如果是已上传的文件,则文件的状态status=“success”,如果是待上传文件,那么文件的状态status=“ready”。我们可以通过文件的状态来处理已上传至服务器和待上传至服务器的文件。

主要代码如下:

<template>
<div>
    <el-button type="text" @click="dialogVisible = true">上传附件</el-button>

   <el-dialog  width="400px" :visible.sync="dialogVisible" append-to-body>
     <div style="float:left">
         <el-upload 
          class="upload-demo"
          ref="upload"
          :limit="10" 
          accept=".txt, .txts, .pdf, .docx" 
          :multiple="true"
          action=" "      
          :on-change="handleFileChange"
          :on-remove="onRemove"
          :before-remove="beforeRemove"
          :on-exceed="fileExceed"
          :auto-upload="false"
          :file-list="fileList" 
          >
          <el-button slot="trigger" size="small" type
  • 6
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
好的,针对你的问题,我可以为你提供以下的思路和代码示例: 1. 在前端页面中添加上传文件的表单,可以使用 VUE 中的 el-upload 组件实现。 2. 在后端代码中编写接收上传文件的接口,可以使用 SpringBoot 中的 MultipartFile 类来处理上传文件。 3. 对于多文件上传前端页面可以使用 el-upload 组件的 multiple 属性,后端接口则可以使用 MultipartFile[] 数组来接收。 下面是一个示例的前端代码: ```vue <template> <el-upload action="/upload" multiple :on-success="handleSuccess" :before-upload="beforeUpload" > <el-button size="small" type="primary">选择文件</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500k</div> </el-upload> </template> <script> export default { methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt500K = file.size / 1024 < 500; if (!isJPG) { this.$message.error('只能上传jpg/png文件'); } if (!isLt500K) { this.$message.error('上传文件大小不能超过 500KB'); } return isJPG && isLt500K; }, handleSuccess(response) { this.$message.success(`上传成功:${response}`); }, }, }; </script> ``` 其中,el-upload 组件的 action 属性表示上传文件的后端接口地址,multiple 属性表示支持多文件上传。beforeUpload 方法用于在上传前对文件进行校验,handleSuccess 方法则是上传成功后的回调函数。 下面是一个示例的后端代码: ```java @PostMapping("/upload") public String handleFileUpload(@RequestParam("files") MultipartFile[] files) { List<String> fileNames = new ArrayList<>(); for (MultipartFile file : files) { String fileName = StringUtils.cleanPath(file.getOriginalFilename()); fileNames.add(fileName); try { Path path = Paths.get(uploadDir + fileName); Files.copy(file.getInputStream(), path, StandardCopyOption.REPLACE_EXISTING); } catch (IOException e) { e.printStackTrace(); } } return "Uploaded files: " + fileNames; } ``` 其中,@RequestParam("files") MultipartFile[] files 表示接收名为 files 的文件数组,uploadDir 表示文件上传的目录路径。 希望这个代码示例能够对你有所帮助!
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值