位置: IT常识 - 正文

el-upload上传文件类型大小限制+手动上传+通过后端给的接口带参数(el-upload上传文件携带参数)

编辑:rootadmin
el-upload上传文件类型大小限制+手动上传+通过后端给的接口带参数 先看效果图:

推荐整理分享el-upload上传文件类型大小限制+手动上传+通过后端给的接口带参数(el-upload上传文件携带参数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:el-upload上传文件类型限制,el-upload上传文件和参数,el-upload上传文件参数,el-upload上传文件必传校验,el-upload上传文件携带参数,el-upload上传文件必传校验,el-upload上传文件给后端,el-upload上传文件夹,内容如对您有帮助,希望把文章链接给更多的朋友!

项目需求:

本地上传文件类型只能是 xml 和 a2l 的 做多上传个数为2个 可以多选上传 每种格式最多上传一个文件 上传为手动上传到服务器 上传错误有相应的提示

需求分析:el-upload上传文件类型大小限制+手动上传+通过后端给的接口带参数(el-upload上传文件携带参数)

  首先上传为手动上传那么文件类型我是打算在选取文件到前端页面的过程中我就处理文件 或者也    可以在上传服务器的时候做判断 我这里选择选取文件的时候做判断 ①是为了展示正确不会有不      满足我需求的文件显示在前端页面用户体验不好 ②是为了在服务器之前处理的话要用到 before-      upload (上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被              reject,则停止上传)钩子函数 而 before-upload 必须有  action (必选参数,上传的地址)才能    触发 而我手动上传我需要通过接口传参所以我不想使用action 填写地址 会有很多不变

  1.上传为手动上传到服务器   :auto-upload="false";

  2.多选上传  :multiple="true"  默认为true

  3.文件类型  accept=".xml,.a2l"

  4.做多上传个数为2个并提示  :limit="2"   :on-exceed="limitCheck" 文件超出个数限制时的钩子

  5.上传错误有相应的提示并且每种格式最多上传一个文件  :on-change="changefile" 文件状态          改变时的钩子,添加文件、上传成功和上传失败时都会被调

代码展示: <el-upload              ref="upload"              :action="url"              :before-remove="beforeRemove"              :on-change="changefile"              accept=".xml,.a2l"              :limit="2"              :on-exceed="limitCheck"              :auto-upload="false"              :multiple="true"              :file-list="fileList">              <el-button                slot="trigger"                size="mini"                type="primary"                style="letter-spacing: 1px"                >选取xml/a2l文件</el-button>              <el-button                style="margin-left: 10px"                size="mini"                type="success"                :loading="submitebtn"                :disabled="this.fileList.length == 0"                @click="submitUpload"                >上传配置</el-button>              <h4 slot="tip" class="el-upload__tip">                只能上传xml/a2l文件              </h4>            </el-upload>data(){ return{ url: "",//action 设置为空字符串即可 fileList: [],//展示在页面上的文件 操作可以对 文件进行 相应的展示和删除 }}methods:{ // 选择的文件超出限制的文件总数量时触发 limitCheck() { this.$message.warning("最多只能上传2个文件"); }, // 上传到服务器 submitUpload() { this.submitebtn = true; let formData = new FormData(); console.log(this.fileList); let newname = this.fileList[0].raw.name; let filea2L = {}; let fileXML = {}; if (newname.substring(newname.lastIndexOf(".")) === ".a2l") { filea2L = this.fileList[0].raw; fileXML = this.fileList[1] ? this.fileList[1].raw : {}; } else { filea2L = this.fileList[1] ? this.fileList[1].raw : {}; fileXML = this.fileList[0].raw; } console.log(fileXML); formData.append("a2lFile", filea2L); formData.append("soaXml", fileXML); formData.append("projectId", this.projectId); this.postRequest("/file/upload", formData).then((res) => { console.log(res); if (res.code == 0) { this.$message({ dangerouslyUseHTMLString: true, message:`<h4>文件上传成功</h4><h4>${filea2L.name?filea2L.name:''}</h4> <h4>${fileXML.name?fileXML.name:''}</h4>`, type:'success', duration:3500 }); this.submitebtn = false; } else { this.$message.error(res.message); this.submitebtn = false; } }); }, // 文件列表移除文件时的钩子 handleRemove(file, fileList) { console.log(file, fileList); this.fileList = fileList; }, // 点击文件列表中已上传的文件时的钩子 handlePreview(file) { console.log(file); }, // 删除文件之前的钩子,参数为上传的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,则停止删除。 beforeRemove(file, fileList) { console.log(file); console.log(fileList); return this.$confirm(`确定移除 ${file.name}?`); }, // 选取文件改变时的操作 可以判断文件类型是否 把不符合的删除缓存 fileList 就是页面缓存的文件 changefile(file, fileList) { console.log(file); console.log(fileList); let arr = []; fileList.forEach((item, index) => { let endname = item.raw.name.substring(item.raw.name.lastIndexOf(".")); arr.push(endname); if (endname != ".a2l" && endname != ".xml") { this.$message.error("上传文件格式只能是 xml 、a2l 格式!"); fileList.splice(index, 1); } }); console.log(arr); if (new Set(arr).size != fileList.length) { fileList.splice(-1); this.$message.warning("选取失败 ! 相同格式的最多上传一次"); } console.log(fileList); this.fileList = fileList; },}
本文链接地址:https://www.jiuchutong.com/zhishi/297828.html 转载请保留说明!

上一篇:pnpm学习(pnmdp)

下一篇:YOLOv5/v7/v8 改进首发最新PWConv核心结构|来自最新CVPR2023顶会,进一步轻量化!测试数据集mAP有效涨点,进一步降低参数量,追求更高的 FLOPS(yolov3 改进)

  • amd radeon hd8500m显卡(amd radeon hd8570m)(amdradeonhd8500m显卡怎么样)

    amd radeon hd8500m显卡(amd radeon hd8570m)(amdradeonhd8500m显卡怎么样)

  • 拼多多一刀砍成什么时候用(拼多多一刀砍成免费拿)

    拼多多一刀砍成什么时候用(拼多多一刀砍成免费拿)

  • 苹果xr前置紫色灯(苹果xr前置紫色后置黑色)

    苹果xr前置紫色灯(苹果xr前置紫色后置黑色)

  • 京券怎么用(京东京劵)

    京券怎么用(京东京劵)

  • 智能短信插件是什么(智能短信插件是干嘛用的)

    智能短信插件是什么(智能短信插件是干嘛用的)

  • 图片不能直接打印怎么回事(图片不能直接打印要重新保存)

    图片不能直接打印怎么回事(图片不能直接打印要重新保存)

  • 笔记本的无线网卡在哪个位置(笔记本的无线网卡是什么)

    笔记本的无线网卡在哪个位置(笔记本的无线网卡是什么)

  • 钉钉直播退出去再进去算时间吗(钉钉直播退出去老师知道吗)

    钉钉直播退出去再进去算时间吗(钉钉直播退出去老师知道吗)

  • 联通虚商是什么意思啊(联通虚商号码安全吗)

    联通虚商是什么意思啊(联通虚商号码安全吗)

  • 星标朋友代表什么(星标朋友有什么意义)

    星标朋友代表什么(星标朋友有什么意义)

  • 恢复聊天记录没有故障维修怎么恢复(恢复聊天记录没有电脑怎么办)

    恢复聊天记录没有故障维修怎么恢复(恢复聊天记录没有电脑怎么办)

  • 乐视手机怎么设置后台应用自启(乐视手机怎么设置屏幕常亮)

    乐视手机怎么设置后台应用自启(乐视手机怎么设置屏幕常亮)

  • 微信投票失败5怎么解决(微信投票失败5是什么原因)

    微信投票失败5怎么解决(微信投票失败5是什么原因)

  • qq音乐可以几个人同时用(qq音乐可以几个设备一起登录)

    qq音乐可以几个人同时用(qq音乐可以几个设备一起登录)

  • 魅族16夜间模式怎么关(魅族16夜间模式在哪里设置)

    魅族16夜间模式怎么关(魅族16夜间模式在哪里设置)

  • 快手开店需要什么条件(快手开店需要什么资料)

    快手开店需要什么条件(快手开店需要什么资料)

  • qq号关联了是不是能看到所有信息(qq号关联了是不是能看到群消息)

    qq号关联了是不是能看到所有信息(qq号关联了是不是能看到群消息)

  • 优活手环怎么开机(优活手环怎么开通Nfc)

    优活手环怎么开机(优活手环怎么开通Nfc)

  • 图虫卡点视频怎么保存(图虫卡点下载)

    图虫卡点视频怎么保存(图虫卡点下载)

  • 苹果x定了闹钟怎么不响(苹果x闹钟设置了不响)

    苹果x定了闹钟怎么不响(苹果x闹钟设置了不响)

  • 关于define与defined的区别(关于define的短语)

    关于define与defined的区别(关于define的短语)

  • Win10打开控制台提示“管理员已阻止mmc.exe

    Win10打开控制台提示“管理员已阻止mmc.exe"?(window如何打开控制台)

  • win10 20H2如何关闭微软自带杀毒软件Defender 简单快速的关闭方法(w10关闭)

    win10 20H2如何关闭微软自带杀毒软件Defender 简单快速的关闭方法(w10关闭)

  • kencli.exe是什么进程 kencli进程查询(kwservice.exe是什么)

    kencli.exe是什么进程 kencli进程查询(kwservice.exe是什么)

  • pcfmgr.exe是什么进程 pcfmgr进程查询(pc是什么文件)

    pcfmgr.exe是什么进程 pcfmgr进程查询(pc是什么文件)

  • 关基系统防SSL证书断供,知道创宇“包办式”国密改造方案省心又安全

    关基系统防SSL证书断供,知道创宇“包办式”国密改造方案省心又安全

  • 实收资本印花税是营业账簿吗
  • 增值税销项税额账务处理
  • 其他应收款期末余额为负数是什么意思
  • 所得税费用贷方表示什么
  • 股东个人固定资产怎么查
  • 车购税申报表如何作废重开
  • 现金日记账支出和收入表格怎么做
  • 退休人员怎么缴纳城镇居民医保
  • 固定资产超过注册资金怎么处理
  • 营业收入管理也是企业财务管理的基本内容
  • 固定资产不动产抵扣新政策
  • 增值税附加税可以抵扣吗?
  • 利息收入要不要交增值税?
  • 免征土地增值税的有哪些
  • 进口设备属于货物贸易吗
  • 将捐赠收入计入资本公积转增增值税
  • 居民小区人防设施主要是什么
  • 在win10系统中,如何限制孩子玩原神游戏
  • 苹果iphone6s plus打电话没有人名
  • 会计科目与账户的关系
  • 暂估主营业务成本怎么冲销
  • 简要说明php web的工作流程
  • u深度u盘启动盘制作工具官网
  • linux的安装和使用
  • 递归 php
  • 报废机器设备如何缴纳增值税
  • 福利企业的税收怎么算
  • 企业缴纳职工社保政策
  • 卡洛里山脉
  • 银行汇票属于银行存款吗
  • 伊兰简介
  • 小额贷款企业收利息吗
  • 顺流交易逆流交易区别
  • php 通信
  • 现在前端的现状
  • 编写jsp程序,实现简易计算机
  • react js 教程
  • springboot+chatgpt+chatUI Pro开发智能聊天工具
  • 代收款用什么会计科目
  • 出售持有股票会计处理
  • mysql5.7性能优化
  • mongodb集群开启auth认证
  • 织梦模板安装完整教程
  • 发票第一联需要盖发票专用章吗
  • 价外费用企业所得税
  • 企业所得税申报错误怎么更改
  • 单位出租不动产,按照5%的征收率计算应纳税额
  • mysql三种安装方式
  • 营业成本和生产费用一样吗
  • 劳务公司的成本有哪些
  • 专项应付款转入资本公积的规定
  • 发票失控进项转出所得税
  • 废品损失是什么要素
  • 本年利润是负数的会计分录
  • 个人股权激励收入税率
  • 股票交易费用计算器小程序
  • 旅游费用如何记账科目
  • win7删除系统文件
  • xp系统打印任务一闪就没有了
  • 硬盘安装在机箱内,属于主机的组成部分
  • cosplay步骤
  • ubuntu系统升级 开机黑屏怎么解决
  • mac 应用
  • xp系统做完了进不去
  • hpm是什么格式的文件
  • centos安装zsh
  • Win10控制面板在c盘哪里
  • android skia opengl
  • perl read
  • JavaScript中的方法名不区分大小写
  • 查看本机开放端口号
  • jquery右击事件
  • js怎么学扎实
  • 江西省税务总局官网
  • 税务局党支部党员大会会议记录
  • 什么是征收率什么是税率
  • 江苏徐州如何开无犯罪记录证明
  • 德税手卷烟海淘
  • 即使我单位是免税单位,签订合同时,也需要贴
  • 水利工程税金的计算公式
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设