Vue+ElementUI 实现下载excel文件模板和上传excel文件

需求如图:点击批量发卡按钮,弹出弹窗实现如下功能在这里插入图片描述
html部分:

<div class="content">
      <div class="content-title">
        <span>批量发卡</span>
      </div>
      <div class="content-body">
        <div>
            <el-form
                label-position="right"
                label-width="18vw"
                
            >
                 <el-form-item label="下载模板:">
                    <el-button
                        class="filter-item"
                        size="mini"
                        type="primary"
                        icon="el-icon-download"
                        @click="downloadExcel()"
                        >下载模板</el-button
                        >
                 </el-form-item>
                <el-form-item label="选择导入文件:" prop="file">
                    <el-upload
                        class="upload-demo"
                        ref="upload"
                        accept=".xls,.xlsx"   
                        :action="UploadUrl()"  
                        :limit="1"   
                        :on-exceed="handleExceed"  
                        :on-change="handleChange"  
                        :on-remove="handleRemove"  
                        :auto-upload="false"
                        :file-list="fileList" >
                        <el-button slot="trigger" size="small" type="primary">选择文件</el-button>
                        <div slot="tip" class="el-upload__tip" style="display: inline-block;margin-left: 20px">只能上传xlsx、xls文件</div>
                    </el-upload>
                </el-form-item>
            </el-form>
        </div>
      </div>
      <div class="content-foot">
        <span @click="cancel">取消</span>
        <span @click="handleUploadFile">上传</span>
      </div>
    </div>
1.下载模板功能

注意:

vue3.0版本的在项目public目录下新建static文件夹,放入“文件模板.xlsx”文件。
vue2.0版本的在项目根目录下的static文件夹,放入“文件模板.xlsx”文件。

在这里插入图片描述

 // 下载模板
    downloadExcel(){
        let a = document.createElement("a");
        a.href = "./static/批量发卡模板.xlsx";
        a.download = "批量发卡模板.xlsx";
        a.style.display = "none";
        document.body.appendChild(a);
        a.click();
        a.remove();
    }
2.选择文件上传功能

使用el-upload实现上传功能
html部分:

               <el-upload
                class="upload-demo"
                list-type="text"
                accept=".xls,.xlsx"    // accept 接受上传的文件类型
                :action="UploadUrl()"   // action 必选参数,上传的地址
                :limit="1"   // limit 最大允许上传个数
                :on-exceed="handleExceed"   // on-exceed  文件超出个数限制时的钩子
                :on-change="handleChange"  // on-change  文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被用
                :on-remove="handleRemove"  // on-remove 文件列表移除文件时的钩子
                :auto-upload="false"  //auto-upload 是否在选取文件后立即进行上传
                :file-list="fileList"  // file-list  上传的文件列表
               >
                    <el-button  type="success" icon="el-icon-upload2">选择文件</el-button>
                    <div class="el-upload__tip" slot="tip">只能上传xlsx、xls文件</div>
               </el-upload>
              
               data(){
                  return {
                      fileList:[]    
                  }
               }
            

js部分:

// 确定上传
    handleUploadFile(){
        console.log('this.fileList',this.fileList)
      // 如果上传的文件列表是空的,给出提示
        if(this.fileList.length === 0){
            return this.$message.warning('请先选择要上传的文件');
        }
        let file  = this.fileList[0]
        console.log(file,'file')
        // 获取到文件的后缀以便于判断文件类型
        if (file.name.indexOf('xlsx') == -1 || file.name.indexOf('xls') == -1) {
            this.$message({
            message: '请选择xlsx、xls格式文件',
            type: 'warning'
            });
            return
        }
        // 把文件转成FormData格式上传
        let dataFile = new FormData()
        dataFile.append('file',this.fileList[0])
        this.$axios({
            url: "/item/upload/card",
            method: "POST",
            params:{
                itemId: this.projectRow.itemId,
            },
            data: dataFile
        }).then((res) => {
            if (res.code=='0') {
                this.$message.success('文件上传成功');
                this.$emit("sure");
            return false;
            } else {
                this.$message.warning(res.message);
            }
        });
    },
     // 文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
    handleChange(file, fileList){
        this.fileList.push(file.raw)
    },
    // 文件超出个数限制时的钩子
    handleExceed(file,fileList) {
        return this.$message.warning('一次只能上传一个文件')
    },
    //因为action参数是必填项,我们使用二次确认进行文件上传时,直接填上传文件的url会因为没有参数导致api报404,所以这里将action设置为一个返回为空的方法就行,避免抛错
    UploadUrl() {
        return ""
    },
    // 文件列表移除文件时的钩子
    handleRemove(file,fileList) {
        this.fileList = fileList
    }
  },
   // 取消
   cancel() {
        this.$refs.upload.clearFiles() //清除上传文件对象
        this.fileList = [] //清空选择的文件列表
        this.$emit("cancel");
    },

注意:点击按钮手动控制上传,需要设置:auto-upload=“false”,如果不设置,默认情况下,当我们选中好了文件,默认就会上传我们所选的文件。

  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用Vue.js和Element UI来实现前端界面,使用Spring Boot来处理后端逻辑来实现文件模板上传下载功能。 首先,你可以创建一个Vue组件来处理文件上传下载的界面。可以使用Element UI中的Upload组件来实现文件上传功能,使用Button组件来实现文件下载功能。在上传组件中,你可以设置上传文件类型和大小限制,并在上传成功后获取到文件的URL或者其他信息。 接下来,在后端使用Spring Boot来处理上传下载的逻辑。你可以创建一个Controller来处理文件上传下载的请求。在文件上传的方法中,你可以使用MultipartFile来接收上传文件,并将其保存到服务器上的某个目录中。在文件下载的方法中,你可以根据传入的文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端。 以下是一个简单的示例代码: 前端Vue.js + Element UI): ```vue <template> <div> <el-upload class="upload-demo" action="/api/upload" :on-success="handleSuccess" :before-upload="beforeUpload" > <el-button type="primary">点击上传</el-button> </el-upload> <el-button type="primary" @click="downloadTemplate">下载模板</el-button> </div> </template> <script> export default { methods: { handleSuccess(response) { // 处理上传成功后的逻辑 console.log(response); }, beforeUpload(file) { // 设置上传文件的类型和大小限制 const fileType = file.type; const fileSize = file.size / 1024 / 1024; // MB const allowedTypes = ['application/pdf', 'application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document']; // 允许的文件类型 const maxFileSize = 10; // 允许的最大文件大小,单位:MB if (!allowedTypes.includes(fileType)) { this.$message.error('只能上传pdf、doc或docx格式的文件'); return false; } if (fileSize > maxFileSize) { this.$message.error(`文件大小超过了${maxFileSize}MB`); return false; } return true; }, downloadTemplate() { // 处理下载模板的逻辑 window.location.href = '/api/download'; }, }, }; </script> ``` 后端(Spring Boot): ```java @RestController @RequestMapping("/api") public class FileController { @PostMapping("/upload") public String uploadFile(@RequestParam("file") MultipartFile file) { // 处理文件上传逻辑 // 可以将上传文件保存到服务器上的某个目录中 return "上传成功"; } @GetMapping("/download") public void downloadTemplate(HttpServletResponse response) { // 处理文件下载逻辑 // 根据文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端 String fileName = "template.docx"; // 下载文件名 String filePath = "/path/to/template.docx"; // 文件在服务器上的路径 try { File file = new File(filePath); InputStream inputStream = new FileInputStream(file); response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "UTF-8")); IOUtils.copy(inputStream, response.getOutputStream()); response.flushBuffer(); } catch (Exception e) { e.printStackTrace(); } } } ``` 这是一个简单的示例,你可以根据自己的需求进行进一步的调整和优化。希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值