vue-simple-uploader文件上传

优点:

1.支持文件、多文件、文件夹上传
2.支持拖拽文件、文件夹上传
3.统一对待文件和文件夹,方便操作管理
4.可暂停、继续上传
5.错误处理
6.支持“快传”,通过文件判断服务端是否已存在从而实现“快传”
7.上传队列管理,支持最大并发上传
8.分块上传
9.支持进度、预估剩余时间、出错自动重试、重传等操作

// 安装:
npm install vue-simple-uploader --save
// 使用:在main.js中:
import uploader from 'vue-simple-uploader'
Vue.use(uploader)

html部分:

 <uploader
 v-if="reFresh"
 :options.sync="options"
 @file-success="onFileSuccess"
 @file-progress="onFileProgress"
 @file-error="onFileError"
 @file-added="onFileAdded"
 class="uploader-example"
 @files-added="onfiles"
 @file-complete="oncomplete"
 @complete="Complete"
 ref="upload">
 <uploader-unsupport></uploader-unsupport>
 <uploader-drop>
 <p>选择上传文件类型</p>
 <uploader-btn style="margin: 20px 20px 20px 50px">选择上传文件</uploader-btn >
 <uploader-btn style="margin: 20px 30px" :directory="true">选择上传文件夹</uploader-btn>
 </uploader-drop>
 <uploader-list></uploader-list>
 </uploader>

组件中的data部分:

data(){
 return{
 options: {
 target: "", //上传地址
 chunkSize: "2048000", //分块大小
 fileParameterName: "file", //上传文件时文件的参数名,默认file
 maxChunkRetries: 3, //最大自动失败重试上传次数
 testChunks: false, //是否开启服务器分片校验
 autoStart: true, //默认 true, 是否选择文件后自动开始上传。
 speedSmoothingFactor: 0.02, //平均速度
 progressCallbacksInterval: 500, //平均速度回調時間
 //更多参数看文档说明
 },
 }
 }

组件中的 methods部分:

methods: {
 // 文件上传
 onFileSuccess(rootFile, file, response, chunk) { 
 let res = JSON.parse(response);
 if (res.res_code != 0) {
 return this.$message.error(res.res_msg);
 }
 this.startIndex();
 },
 // 文件上传进度的回调
 onFileProgress(rootFile, file, chunk) {
 console.log(
 `上传中 ${file.name},chunk:${chunk.startByte / 1024 / 1024} ~ ${
 chunk.endByte / 1024 / 1024
 }`
 );
 this.U_success = "1";
 },
 // 文件上传出错
 onFileError(rootFile, file, response, chunk) {
 console.log(rootFile);
 console.log(response);
 },
 //判断文件是否已经上传
 onfiles(files, fileList) {
 if (files.length == 0) {
 return this.$message.error("文件已存在,请勿重复上传!");
 }
 },
 Complete() {
 console.log("上传完毕");
 this.U_success = "上传完毕";
 },
 //清空上传完成的文件列表
 oncomplete() {
 // this.$refs.upload.files = [];
 // this.$refs.upload.fileList = [];
 console.log("上传成功!");
 // this.$message.success("上传成功!");
 },
 }

遇到的问题:
在初始化options里将query设为函数,但是不能携带动态参数,如动态路径 因为options是在实例化的时候传入配置项,所以在传动态上传路径的时候我用的是v-if销毁组件 也是因为上传列表不好清除 其中上传成功后我用的是组件中的complete时间,监听到文件上传成功后 this.refs.upload.files = [ ]; this.refs.upload.fileList = [ ]; 清空上传列表 在文件重复上传后就会有问题,就算清空了,所有的事件都没有监听到 this.refs.upload.files和this.refs.upload.fileList 里面有数据,但是所有流程走完它就会把重复上传的文件添加到files、fileList里面,所以用了 setTimeout(function(){ this.refs.upload.files = [ ]; this.refs.upload.fileList = [ ]; },50); 后来需求改了就没有在代码中体现 还是用了销毁组件的方式来解决这些问题

参考 https://www.cnblogs.com/xiahj/p/vue-simple-uploader.html#2-%E5%85%B3%E4%BA%8Evue-simple-uploader
记录一下自己用到的文件上传组件,具体内容参考文档 vue-simple-uploader文档 simple-uploader.js文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容