位置: 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 改进)

  • 微信营销的30个实用技巧(99个微信营销技巧,史上最全)

    微信营销的30个实用技巧(99个微信营销技巧,史上最全)

  • 快手怎么保存视频到本地相册(快手怎么保存视频不带快手号)

    快手怎么保存视频到本地相册(快手怎么保存视频不带快手号)

  • 苹果音量键怎么区分铃声和音量(苹果音量键怎么调节铃声)

    苹果音量键怎么区分铃声和音量(苹果音量键怎么调节铃声)

  • 抖音本场点赞能换钱吗(抖音本场点赞是不是音浪)

    抖音本场点赞能换钱吗(抖音本场点赞是不是音浪)

  • 微信不退群又隐藏怎么设置(微信不退群又隐藏自己名字)

    微信不退群又隐藏怎么设置(微信不退群又隐藏自己名字)

  • 怎样不删除好友又不用看到对方信息(怎样不删除好友又不用看到信息呢)

    怎样不删除好友又不用看到对方信息(怎样不删除好友又不用看到信息呢)

  • 百家号里的视频标签是什么(百家号里的视频和小视频有什么区别)

    百家号里的视频标签是什么(百家号里的视频和小视频有什么区别)

  • 原装充电器和不是原装有什么区别(原装充电器和不是原装对手机有影响吗)

    原装充电器和不是原装有什么区别(原装充电器和不是原装对手机有影响吗)

  • 显示器闪烁抖动是什么原因(显示器闪烁抖动是驱动板还是高压板的问题)

    显示器闪烁抖动是什么原因(显示器闪烁抖动是驱动板还是高压板的问题)

  • 哪些行为会被闲鱼降权(哪些行为会被征信)

    哪些行为会被闲鱼降权(哪些行为会被征信)

  • 荣耀手机安装未知应用在哪里设置(荣耀手机安装未知)

    荣耀手机安装未知应用在哪里设置(荣耀手机安装未知)

  • 苹果手机激活前有充电记录(苹果手机激活前屏幕使用时间)

    苹果手机激活前有充电记录(苹果手机激活前屏幕使用时间)

  • 剪映如何导入qq音乐中的音乐(剪映如何导入汽水音乐)

    剪映如何导入qq音乐中的音乐(剪映如何导入汽水音乐)

  • 怎么更改微信名(微信公众号怎么更改微信号)

    怎么更改微信名(微信公众号怎么更改微信号)

  • tlc做系统盘可以吗(tlc寿命做系统盘可以吗)

    tlc做系统盘可以吗(tlc寿命做系统盘可以吗)

  • 我的卡包在哪里找(京东我的卡包在哪里)

    我的卡包在哪里找(京东我的卡包在哪里)

  • pe-tl10是什么型号(peg10是什么)

    pe-tl10是什么型号(peg10是什么)

  • 南京地铁乘车码能刷几个人(微信怎么开通南京地铁乘车码)

    南京地铁乘车码能刷几个人(微信怎么开通南京地铁乘车码)

  • 微信怎么用身份证实名验证(微信怎么用身份证找回账号密码)

    微信怎么用身份证实名验证(微信怎么用身份证找回账号密码)

  • oppo17上市时间(oppor17什么时候出来的)

    oppo17上市时间(oppor17什么时候出来的)

  • 自己怎么创建公众号(自己怎么创建公司)

    自己怎么创建公众号(自己怎么创建公司)

  • hotfix是什么

    hotfix是什么

  • win10无法上网,网络连接有感叹号是怎么回事?(win10无法上网,显示灰色的飞行模式)

    win10无法上网,网络连接有感叹号是怎么回事?(win10无法上网,显示灰色的飞行模式)

  • 私立学校要交社保吗
  • 北京增值税发票查验平台
  • 视同销售收入是纳税调整项目吗?
  • 销售二手车需要什么资质
  • 视同销售收入是纳税调整项目吗
  • 小规模纳税季收入怎么算
  • 个体工商户可以开发票吗
  • 企业咨询费入什么科目
  • 长期借款费用会减少吗
  • 财政补贴的概念是什么?其性质是什么?
  • 现金比率的计算公式是指
  • 结转周转材料成本差异会计分录
  • 小规模纳税人查账征收所得税税率
  • 国外公司怎么付款给国内
  • 年度员工离职率的计算公式
  • 旧的活动板房多少钱一个
  • 增值税专用发票可以开电子发票吗
  • 企业里工会
  • 建筑企业所得税怎么算举例说明
  • 土地增值税通过什么科目核算
  • 企业资产损失会计处理
  • 工龄补偿款
  • 中介公司收取中介费过高违法吗
  • 中秋节福利产品清单
  • php read
  • 布列塔尼岛屿
  • vue能实现什么
  • 勾选确认发票后能撤销吗
  • phpsession和cookie
  • 小规模纳税人要交企业所得税吗?
  • 分公司不能享受所得税优惠
  • opencv的函数
  • php 方法
  • cookie set
  • php图片代码
  • 先收到保险公司赔付然后赔给顾客医药费怎么做帐
  • 增值税专用发票上注明的价款含税吗
  • 商贸公司库存商品有哪些
  • 织梦相关文章调用
  • 基于sqlite特殊字符转义的实现方法
  • 土地增值税扣除项目20%
  • mysql怎么修改
  • sqlserver2012完全卸载
  • 一般纳税人接受捐赠的固定资产,捐赠方提供了有关凭证
  • 发票的类型分为哪几类
  • 转让技术所有权是其他业务收入吗
  • 记账凭证后面附发票第几联
  • 母子公司无偿划转土地
  • 预付账款的相关认定
  • 减值损失和减值损失区别
  • 工程款外地预缴哪些税
  • 分公司做账报税
  • 个体户建账吗
  • 企业短期借款可以是个人吗
  • Windows Server 2003系统进程中NETWORK SERVICE相关知识详解
  • win2003回收站
  • CentOS7的hostnamectl命令使用详解
  • centos挂载cd
  • win8分盘怎么分
  • ubuntu20.04亮度调节
  • dell t110服务器
  • 图片缩略图是什么意思
  • opensuse安装显卡驱动
  • speedmgr.exe - speedmgr是什么进程 有什么用
  • w10组策略
  • mac修改java版本
  • linux定时任务详解
  • Unity3D 事件
  • opengles版本过低怎么办
  • opengl立体模型
  • js获取url的html
  • layui nodejs
  • android源码分析实录
  • unity3d最新api
  • jquery移动版
  • android退出程序代码
  • 顺丰收取关税合理吗
  • 充电桩充电怎么收费,几种收费方法
  • 区里的地税局局长是谁
  • 河北省电子税务局手机登录入口
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设