IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> el-upload实现手动上传多文件 -> 正文阅读

[JavaScript知识库]el-upload实现手动上传多文件

引用:https://www.jianshu.com/p/e449196a8d39

    <el-upload
      multiple
      action=""
      :limit="5"
      :on-change="handleChange"
      :on-remove="handleRemove"
      :auto-upload="false"
      :file-list="fileList"
      :on-exceed="handleExceed"
    >
      <el-button slot="trigger" size="small" type="primary" @click="resetFileCount">选取文件</el-button>
      <el-button size="small" type="success" @click="submitUpload">上传到服务器{{url}}</el-button>
    </el-upload>
   resetFileCount(){
          this.fileCount = 0;
        },
        handleChange(file,fileList){// 文件状态改变钩子
          // 第一次on-change获取fileList
          console.log("ccccccccccccccccccc",this.fileCount);
          console.log("**********************************");
          if (this.fileCount === 0){
            // 多个文件fileList会变化
            this.oldFileList = Object.assign(this.fileList);
          }

          console.log(this.oldFileList,2222);
          // file.raw // 文件内容
          // 改文件是否已经存在上传列表中  some判断是否满足要求
          let isTrue = this.oldFileList.some((f)=>{
            console.log(f.name,file.name);
            return f.name === file.name})


          if (isTrue){
            this.$message.warning("请勿重复上传文件!")
            fileList.pop()
            return
          }
          this.fileList = fileList

          this.fileCount++;

        },
        handleRemove(file,fileList){// 删除上传文件
          this.fileList = fileList
        },

      submitUpload(){ // 提交点击
        if (this.fileList.length === 0){
          this.$message.warning("请先选择上传文件!")
          return
        }
        this.uploadFile()
      },
        uploadFile(){//文件上传方法
          let formData = new FormData();
          this.fileList.forEach(file =>{
            //multipartFiles 后台接收名字
            formData.append("multipartFiles",file.raw)
          })
          console.log(formData);
          //后端用 multipartFiles 接收
          axios.post(this.url,formData,{"Content-Type":"multipart/form-data"})
        },
        dialogClose(){ // 关闭dialog
          this.$parent.closeAttachmentDialog()
        },
        handleExceed(){// 超出限制个数钩子
          this.$parent.handleExceed()

        },

遇到的问题:
一次性上传多个文件时,他的on-change就会执行很多次,也会上传很多次。。上面的代码是自动上传的,也有判断文件个数是否等于 fileList 的长度是否相等,相等再上传。。。
一次性上传多个文件时,判断上传文件是否重复,设置一个fileCount 文件计数器
在这里插入图片描述
在这里插入图片描述
每次选择文件的时候设置为0 ,将最初的fileList存起来
在这里插入图片描述
不然每一个文件都会执行on-change,都会初始化fileList,就不能根据fileList判断是否有这个文件


在这里插入图片描述


在这里插入图片描述
在这里插入图片描述

引用:https://blog.csdn.net/qq_42394457/article/details/96769170、https://blog.csdn.net/weixin_43915587/article/details/91953230

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-01-28 11:49:07  更:2022-01-28 11:51:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 20:02:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码