element el-upload 上传文件组件封装

本文介绍如何在Vue.js项目中封装Element UI的el-upload组件,实现单个文件上传,拖拽上传,限制文件类型及大小,以及提供取消上传和删除文件的功能。示例包含组件的代码结构和使用方式。
摘要由CSDN通过智能技术生成

场景:一次只能上传一个文件,单选文件上传、输入文件名、拖拽、最大50M,支持ppt/word/excel/pdf/jpg/png/,取消上传,可上传多个,删除文件。
效果:
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

组件index.vue

<template>
  <div class="applyUpload">
    <div class="apply_content">

      <div class="upload_content">
        <div class="upload_item">
          <div class="fileName"><i style="color:red">*</i>文件名称:</div>
          <el-input v-model="fileName" maxlength="10" show-word-limit clearable></el-input>
        </div>
        <div class="upload_item">
          <el-upload v-loading="loading" class="avatarUpload" action="#" :accept="fileAccepteList"
            :on-change="beforeAvatarUpload" :on-progress="progress" :http-request="handleRequest" drag ref="upload"
            :auto-upload="false" :limit="1" :on-exceed="limitCheck" :on-remove="handleRemove">
            <i class="el-icon-upload"></i>
            <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
            <div slot="tip" class="el-upload__tip">只允许上传{
   {
   fileAccepteList}}格式的文件,且文件大小不超过50M</div>
          </el-upload>
        </div>
        <div class="upload_item">
          <div class="upload_btn">
            <div class="confirm" v-if="loading == false && fileNum > 0" @click="uplaodConfirm">确定上传</div>
            <div class="cancel" v-if="loading ==  true" @click="closeUploadDialog">取消上传</div>
          </div>
        </div>

      </div>
      <div class="fileList">
        <div class="file_item" v-for="(item,index) in allFileList2" :key="index">
          <div class="file_info">
            <div>{
   {
   index+1}}.</div>
            <div :title="item.fileName">{
   {
   item.fileName}}</div>
            
          </div>
          <div class="del_btn"> 
            <div>{
   {
   item.filePhoto}}</div>
            <div>{
   {
   (item.fileSize/1024/1024).toFixed(2)}}M</div>
            <div @click="delFile(item,index)">
              <i class="el-icon-close"></i></div> </div>
        </div>
      </div>
    </div>

    <span class="footer_btn">
      <el-button type="" @click.native="cancel">取消</el-button>
      <el-button type=
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值