一,前言
最近在用Vue,然后上传文件时需要显示进度,于是网上搜了一下,经过自己实测终于也弄明白了
二,效果
三,代码
HTML代码
<div id="app"> <h4>上传文件:</h4> <p class="input-zone"> <span v-if="filename">{{filename}}</span> <span v-else>+请选择文件上传+</span> <input type="file" name="file" value="" placeholder="请选择文件" @change="upload" multiple="multiple" /> </p> <p>上传进度:</p> <div class="progress-wrapper"> <div class="progress-progress" :style="uploadStyle"></div> <div class="progress-rate">{{(uploadRate*100).toFixed(2)}}%</div> </div> </div>
CSS代码
.input-zone { width: 500px; color: blue; font-size: 14px; position: relative; } .input-zone input[type='file'] { opacity: 0; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2; } .progress-wrapper { position: relative; height: 50px; border-radius: 5px; background-color: lightgrey; } .progress-wrapper .progress-progress { position: absolute; left: 0; top: 0; height: 100%; width: 0%; border-radius: 5px; background-color: darkturquoise; z-index: 1; } .progress-wrapper .progress-rate { position: relative; text-align: center; font-size: 14px; line-height: 50px; height: 100%; z-index:2;}
JS代码
var app = new Vue({ el: "#app", data: { uploadRate: 0, filename: '', uploadStyle: { width: '0%' } }, methods: { upload: function (e) { var vm = this; var formData = new FormData(); formData.append("name", "Alax"); for (var i = 0; i < e.target.files.length; i++) { var file = e.target.files[i]; //取第1个文件 formData.append("file", file); vm.filename = file.name; console.log(file); } var config = { headers: { 'Content-Type': 'multipart/form-data' }, onUploadProgress: function (e) { console.log("进度:"); console.log(e); //属性lengthComputable主要表明总共需要完成的工作量和已经完成的工作是否可以被测量 //如果lengthComputable为false,就获取不到e.total和e.loaded if (e.lengthComputable) { var rate = vm.uploadRate = e.loaded / e.total; //已上传的比例 if (rate < 1) { //这里的进度只能表明文件已经上传到后台,但是后台有没有处理完还不知道 //因此不能直接显示为100%,不然用户会误以为已经上传完毕,关掉浏览器的话就可能导致上传失败 //等响应回来时,再将进度设为100% vm.uploadRate = rate; vm.uploadStyle.width = (rate *100).toFixed(2)+ '%'; } } } }; axios.post("/ajaxPage/VueUpload.aspx?method=upload", formData, config) .then(function (data) { console.log(data); var json = data.data; //后台实际返回的结果 if (json.result) { vm.uploadRate = 1; vm.uploadStyle.width = '100.00%'; } else { alert(json.msg); } }) .catch(function (err) { console.log(err); }); } } })
四,总结
1.其实单文件上传和多文件上传的区别就是 input标签中多了一个属性
multiple="multiple"
2.onuploadprogress 事件中显示上传为100%并不准确,一定要等到响应回来才能认为完成了100%,不然用户此时关闭了浏览器的话,上传就失败了。或者有其它逻辑时,此时点提交,就会导致后台找不到上传的文件路径等问题。
总结
以上所述是小编给大家介绍的axios+Vue实现上传文件显示进度功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
本文向大家介绍JS实现批量上传文件并显示进度功能,包括了JS实现批量上传文件并显示进度功能的使用技巧和注意事项,需要的朋友参考一下 今天接受项目中要完成文件批量上传文件而且还要显示上传进度,一开始觉得这个应该不是很麻烦,当我在做的时候遇到了很多问题,很头疼啊。 不过看了别人写的代码,自己也测试过,发现网上好多都存在一些问题,并不是自己想要的。然后自己查阅各种资料,经过自己总结,最终完成了这个功能。
本文向大家介绍Vue实现带进度条的文件拖动上传功能,包括了Vue实现带进度条的文件拖动上传功能的使用技巧和注意事项,需要的朋友参考一下 1. 基本界面 2. 检测拖动事件 首先让页面支持文件拖拽,在 Vue 的 mounted() 函数中添加代码: 当把文件拖动到浏览器的拖动区域时,会触发三种事件: 文件第一次进入拖动区时,触发 dragenter 事件 文件在拖动区来回拖拽时,不断触发 drag
本文向大家介绍Jquery和BigFileUpload实现大文件上传及进度条显示,包括了Jquery和BigFileUpload实现大文件上传及进度条显示的使用技巧和注意事项,需要的朋友参考一下 实现方法:用到了高山来客 的bigfileupload组件,用高山来客的方法,弹出一个模式窗口,然后不停刷新获取进度,始终觉得体验感不好,于是想到用jquery来实现无刷新进度显示,因为提交页面后, 不能
问题内容: 我有上传表格,允许用户上传多个文件。我决定,如果文件很大,则进度条会很好。下面是我的源代码。我是jQuery的新手,通常我只会使用php,但是我发现ajax更加用户友好。 图像上传正常,数组发送到ajax,但进度条不动。实际上,调用这两个函数的console.log都不会产生这种情况。有没有正确的方法来调用我的ajax请求中的函数,以使此进度条正常工作。 beforeSubmit:be
本文向大家介绍vue实现文件上传读取及下载功能,包括了vue实现文件上传读取及下载功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了vue实现文件上传读取及下载的具体代码,供大家参考,具体内容如下 文件的上传利用input标签的type="file"属性,读取用FileReader对象,下载通过创建a标签实现 关于vue.js的学习教程,请大家点击专题vue.js组件学习教程、Vu
本文向大家介绍servlet+jquery实现文件上传进度条示例代码,包括了servlet+jquery实现文件上传进度条示例代码的使用技巧和注意事项,需要的朋友参考一下 现在文件的上传,特别是大文件上传,都需要进度条,让客户知道上传进度。 本文简单记录下如何弄进度条,以及一些上传信息,比如文件的大小,上传速度,预计剩余时间等一些相关信息。代码是匆忙下简单写的,一些验证没做,或代码存在一些隐患,不