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

  • 千万级预算怎样做好渠道运营?(一千万的工程预算一般几个点)

    千万级预算怎样做好渠道运营?(一千万的工程预算一般几个点)

  • vmware workstation安装教程(vmware workstation安卓版)

    vmware workstation安装教程(vmware workstation安卓版)

  • 为什么美团订单删不掉(为什么美团订单没有声音)

    为什么美团订单删不掉(为什么美团订单没有声音)

  • 手机的返回键突然按不了了是怎么回事(手机返回键突然失灵是什么原因)

    手机的返回键突然按不了了是怎么回事(手机返回键突然失灵是什么原因)

  • 密码输入对了连不上网(密码输入对了,wifi连不上是什么原因)

    密码输入对了连不上网(密码输入对了,wifi连不上是什么原因)

  • 华为三键导航如何开(华为三键导航如何分屏)

    华为三键导航如何开(华为三键导航如何分屏)

  • 电脑有必要独立声卡吗(电脑要独立显卡吗?)

    电脑有必要独立声卡吗(电脑要独立显卡吗?)

  • qq红包行为异常封7天(qq红包检测到您的行为异常)

    qq红包行为异常封7天(qq红包检测到您的行为异常)

  • 卡贴费电吗(卡贴很耗电吗)

    卡贴费电吗(卡贴很耗电吗)

  • 小米5x用OTG显示不出来

    小米5x用OTG显示不出来

  • 华为p30pro可以反向充电吗(华为p30pro有反向充电吗?)

    华为p30pro可以反向充电吗(华为p30pro有反向充电吗?)

  • hdr10是什么意思(hdr10和hdr400)

    hdr10是什么意思(hdr10和hdr400)

  • 手机微课怎么制作(手机怎样制作微课)

    手机微课怎么制作(手机怎样制作微课)

  • 未接通对方能收到吗(未接通会响铃吗)

    未接通对方能收到吗(未接通会响铃吗)

  • shelper指的是什么软件(shelper是啥软件)

    shelper指的是什么软件(shelper是啥软件)

  • 网络直播房间内容存储时间不少于多少天备查(网络直播房间布置图)

    网络直播房间内容存储时间不少于多少天备查(网络直播房间布置图)

  • 抖音橱窗必须开通淘宝联盟吗(抖音橱窗必须开通聚合账户有个扣款吗)

    抖音橱窗必须开通淘宝联盟吗(抖音橱窗必须开通聚合账户有个扣款吗)

  • wegame怎么实名认证(wegame怎么实名制)

    wegame怎么实名认证(wegame怎么实名制)

  • 手机qq小程序怎么关(手机qq小程序在哪儿)

    手机qq小程序怎么关(手机qq小程序在哪儿)

  • 怎样设置电话正在通话中(怎样设置电话正在通话中苹果手机)

    怎样设置电话正在通话中(怎样设置电话正在通话中苹果手机)

  • icloud怎么申请退款(icloud怎么退费)

    icloud怎么申请退款(icloud怎么退费)

  • qq手机文件保存位置(qq手机文件保存的位置在哪里)

    qq手机文件保存位置(qq手机文件保存的位置在哪里)

  • 文件保存了却找不到(文件保存以后找不到了)

    文件保存了却找不到(文件保存以后找不到了)

  • 吃鸡显卡用GTX1060好还是RX580好?(吃鸡显卡推荐配置1060 5g)

    吃鸡显卡用GTX1060好还是RX580好?(吃鸡显卡推荐配置1060 5g)

  • 详细解读:MIT经典的语义分割数据集ADE20K,附下载链接(mit?)

    详细解读:MIT经典的语义分割数据集ADE20K,附下载链接(mit?)

  • 什么时候要计提坏账准备
  • 所得税汇算清缴账务处理
  • 累计扣除税额
  • 政府补贴是否要交企业所得税
  • 员工报销公司是哪个部门
  • 小企业会计准则以前年度损益调整
  • 小规模纳税人转让土地使用权
  • 支付违约金未取得正规发票能不能在税前列支
  • 固定资产评估减值后如何入账
  • 无形资产摊销是谨慎性原则吗
  • 应收账款核销后收回
  • 从公司账户转给个人账户取出来发给员工做过节费
  • 办公室租赁合同需要交哪些税额?
  • 企业拆迁补偿款要交哪些税
  • 物流辅助服务需要办许可证吗
  • 固定资产和在建工程占所有者权益的占比
  • 税务局怎么知道你的收入
  • 消费满额赠礼
  • 公司做账挂名字
  • 金税三期得死多少企业
  • 从租计征房产税租金收入含税吗
  • 所得税免税项目
  • 对个体工商户个人的认识
  • deepin切换系统
  • 转账和电汇哪个便宜
  • iphone7plus怎么设置5g网络
  • linux yum update
  • 怎么激活win10专业版
  • 营改增后房地产会计账务处理
  • PHP:curl_share_setopt()的用法_cURL函数
  • WordPress导航菜单权限控制
  • 员工工伤保险报销条件
  • 销售合同怎么计提折旧
  • 多提附加税跨年怎么计算
  • Vue3 + Vite + TypeScript + dataV 打造可视化大屏
  • 投资性房地产出售时其他综合收益
  • 预计可变现净值影响账面价值吗
  • 工地临时设施搭设原则是什么?
  • yii2入门
  • php使用什么开发工具
  • lincom命令
  • 旅行社代订酒店如何入账
  • 完美破费是什么意思
  • 计提坏账准备不会影响应收账款账面价值
  • 自然人独资的有限责任公司交什么税
  • 社保代扣代缴的规定
  • 专用发票超过360天未认证
  • 工资不纳税项目
  • 国家税务总局公告2011年第25号公告
  • 税法中特许权费包括哪些
  • 内账会计的岗位职责
  • 城市维护建设税的计税依据
  • 专用发票红冲有时间限制吗
  • 转销无法收回的应收账款会计分录
  • 实收资本未到账减资要交税吗
  • 建账的基本步骤
  • 工业企业检查表
  • unix怎么切换用户
  • win7桌面提示7601
  • win8更新8.1
  • ubuntu多桌面切换
  • mac上怎么查看qq聊天记录
  • win8资源管理器在哪
  • RHEL5 Apache+Tomcat整合,同时支持jsp与php
  • win8系统如何
  • slee401.exe - slee401是什么进程 有什么用
  • win7系统使用ituns设置iphone铃声图文教程
  • win7登录不进去
  • win10升级版本后还要激活吗
  • eclipce System.loadLibrary报错
  • perl -pi
  • cocos2dx 3.3 helloworld 入门 学习与详解
  • jquery左右移动动画效果
  • activity生命周期的方法
  • jQuery Ajax 全局调用封装实例代码详解
  • python 正则 \s
  • 单位个人所得税网上申报流程
  • 税务上的关联企业指哪些
  • 如何查询有没有交医保费用
  • 公司注册资本印花税的税率是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设