位置: 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上传文件,内容如对您有帮助,希望把文章链接给更多的朋友!

el-upload实现上传文件并展示进度条(el-upload上传文件大小限制)

el-upload在实现文件上传时无法触发on-progress钩子,即使调用后端接口并成功的情况下都无法触发,可以通过如下配置来解决:

const config = { onUploadProgress: progressEvent => { if (progressEvent.lengthComputable) { this.uploadProgress = Math.round((progressEvent.loaded / progressEvent.total) * 100) console.log('progressEvent>>', progressEvent) console.log('uploadProgress>>', _this.uploadProgress) } } }

随后将config添加至调用后端接口,即可成功获取进度~

html:

前端-上传文件获取进度条: <el-upload v-show="!fileList.length" ref="fileUpload" class="upload-demo" style="display: inline-block;height: 32px;margin-left: 8px" action="#" :file-list="fileList" :http-request="uploadVersion" :on-change="handleChange" :on-success="handleSuccess" :on-progress="handleProgress" :on-error="handleError" :auto-upload="true" :show-file-list="false" > <!-- icon_upload.svg--> <el-button type="primary" style="height: 32px;display: flex;align-items: center"><svg-icon icon-class="icon_upload" style="margin-right: 8px" />上传文件</el-button> <!-- <el-input v-model="uploadForm.filename" placeholder="请选择">--> <!-- &lt;!&ndash; <template slot="append"><el-button&ndash;&gt;--> <!-- &lt;!&ndash; size="mini"&ndash;&gt;--> <!-- &lt;!&ndash; >&ndash;&gt;--> <!-- &lt;!&ndash; 上传文件&ndash;&gt;--> <!-- &lt;!&ndash; </el-button></template>&ndash;&gt;--> <!-- </el-input>--> </el-upload> <!-- <el-button size="small" @click="sendClick">上传</el-button>--> <div v-if="fileElProgress"> <div class="el-progress-div"> <div><div v-loading="true" style="display: inline-block;width: 24px; height: 16px; padding-right: 8px;" />{{ fileName }}</div> <span> <span style="display: inline-block;margin-right: 8px">{{ progressPercent }}%</span> <el-button type="text" @click="cancelUpload">取消</el-button> </span> </div> <el-progress :percentage="progressPercent" :text-inside="false" :color="customColors" :stroke-width="2" /> <!-- :stroke-width="16" status="scuccess"--> </div> <template v-if="!fileElProgress"> <div v-for="item in fileList" :key="item.name" class="fail-list"> <div class="list-item"> <span :style="{color:showFailTip?'#FF3D00':'#fff' }"> <svg-icon :icon-class="showFailTip? 'icon_error_file': 'icon_success_file'" /> {{ item.name }} </span> <span style="float: right;display: flex;align-items: center;"> <span style="color: #878D99;display: inline-block;margin-right: 16px">{{ showFailTip ? '失败':'成功' }}</span> <!-- <span>{{ '失败' }}</span>--> <el-button style="color: #00E3FF" type="text" size="small" @click="fileList = []">删除</el-button> <el-button v-show="showFailTip" style="color: #00E3FF" type="text" size="small" @click="sendClick">重新上传</el-button> </span> </div> </div> </template>

JS部分

data() { return { // 进度条 fileList: [], showFailTip: false, customColors: [ { color: 'rgba(223,228,237,0.10)', percentage: 0 }, { color: '#00adc9', percentage: 100 } ], fileElProgress: false, fileProgressText: '', progressPercent: 0, } methodss:{ uploadVersion(params) { const _this = this this.uploadForm.filename = params.file.name this.fileFormData = new FormData() this.fileFormData.append('file', params.file) this.fileFormData.append('md5File', params.file) this.fileName = params.file.name const config = { onUploadProgress: progressEvent => { if (progressEvent.lengthComputable) { _this.uploadProgress = Math.round((progressEvent.loaded / progressEvent.total) * 100) console.log('progressEvent>>', progressEvent) console.log('uploadProgress>>', _this.uploadProgress) this.fileElProgress = true if (this.progressPercent < 99) { this.progressPercent = _this.uploadProgress } else { this.fileProgressText = '正在上传' } } } } uploadFile(this.fileFormData, config).then(res => { if (res.data === 'success') { this.fileProgressText = '上传成功' } else { this.showFailTip = true } this.fileElProgress = false }) }, } },
本文链接地址:https://www.jiuchutong.com/zhishi/285147.html 转载请保留说明!

上一篇:格洛里亚附近的码头和糖面包山,巴西里约热内卢 (© f11photo/Getty Images)(格洛利亚酒店)

下一篇:如何在vue中实现文件预览功能(vue实战技巧)

  • 企业所得税怎么算出来
  • 企业所得税和预提所得税
  • 0税率开票如何做账
  • 退回的附加税能退回来吗
  • 金蝶销售订单和采购订单关联
  • 个体工商户需要报税吗
  • 企业购买房产每年需要交什么税
  • 同一笔业务可以开多张发票吗
  • 营业账簿是什么意思
  • 以前年度管理费用多计
  • 专项科研经费
  • 发票失控成本怎么处理
  • 物业管理公司如何纳税
  • 以前年度的税金及附加
  • 增值税专票盖章正确位置
  • 个人所得税退税截止日期2023
  • 发票是不是一定要三签才能开
  • 垫付的工程款可以起诉要回吗
  • 租金和物业费怎么计算
  • 应收账款 转让
  • 收到股利的现金会计分录
  • 加盟费是一年一收还是终身的
  • 包工包料装修
  • 某市财政收到林业基金收入分录
  • 应收账款计提坏账准备是根据什么会计信息质量要求
  • 企业买金税盘做什么科目
  • 增值税出口退税为什么不属于政府补助
  • 房屋修理费用
  • 减值准备递延所得税资产
  • 特定业务预缴
  • 发票多开了一张怎么处理?
  • 针对多用户实现什么功能
  • spring5和6差别大吗
  • 零售企业商品盘点发生溢余后,在查明原因前,应按
  • mongodb优点
  • 玉米 收购
  • 普票和专票的
  • 专票和普票都是13个点嘛
  • 减免申报明细表怎么填
  • sql2012附加数据库方法
  • 公司制作横幅计入什么科目?
  • 政府对企业提交的项目申请报告主要从等方面进行核准
  • 酒店购买天然气开票的摘要写什么
  • 进项税转出金额怎么算
  • 发票一般会失效几天
  • 药品进销差价会计科目
  • 电梯安装费如何分摊
  • 发出存货的计价方法一经确定,不得随意改变
  • 小规模纳税人购进税控设备如何抵扣
  • 设备5年直线法计提折旧怎么做?
  • 发票盖发票专用章
  • 清空mysql数据库
  • centos6.10安装教程
  • windows7休眠唤醒设置
  • Win10预览版桌面图标和任务栏不翼而飞怎么办?
  • 涌泉的准确位置图 图解
  • 没有vcd怎么放光盘
  • 电脑无法启动windows7
  • 查看电伊
  • WIN7系统如何设置表格默认保存位置
  • Ubuntu系统怎么设置IP
  • centos搭建v2
  • linux单个文件夹文件数量
  • linux创建vg
  • win8运行速度慢怎么办
  • win10教育版登录
  • linux下VSFTP 530 Permission denied错误的解决办法
  • cocos2dx官方教程
  • unity3d官方
  • unity描边shader
  • android 样式
  • python字符串处理为年月日
  • 内存优化有哪些方法
  • pygame如何加载图片
  • JavaScript中常用的数据类型有
  • android studio官网
  • ubuntu如何下载
  • jquery easyui有哪些特点
  • 江苏省税务厅电话
  • 运输合同的印花税怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设