|
|
@ -1,17 +1,31 @@ |
|
|
|
<template> |
|
|
|
<div class="hello"> |
|
|
|
<form id="fromCont" method="post"> |
|
|
|
<input @change="choseFile" id="file" multiple="multiple" type="file" /> |
|
|
|
<el-divider content-position="left">大文件上传</el-divider> |
|
|
|
<form id="fromCont" method="post" > |
|
|
|
<div class="fileUpload"> |
|
|
|
选择文件<input @change="choseFile" id="file" multiple="multiple" type="file" /> |
|
|
|
</div> |
|
|
|
</form> |
|
|
|
<el-button @click="getFile">上传</el-button> |
|
|
|
<span |
|
|
|
<el-button @click="getFile" :disabled="limitFileSize" type="primary" size="medium" class="uploadBtn">上传文件</el-button> |
|
|
|
<div class="el-upload__tip">请上传不超过5MB的文件</div> |
|
|
|
<div class="list"> |
|
|
|
<transition-group name="list" tag="p"> |
|
|
|
<div class="list-item" v-for="(item,i) in uploadList" :key="i" > |
|
|
|
<i class="el-icon-document"></i> |
|
|
|
<span>{{ item.name }}</span> |
|
|
|
<span v-if="file" class="percentage" >{{percentage}}%</span> |
|
|
|
<el-progress :show-text='false' :text-inside="false" :stroke-width="2" :percentage="percentage"></el-progress> |
|
|
|
</div> |
|
|
|
</transition-group> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- <span |
|
|
|
v-if="this.file" |
|
|
|
>{{Math.floor(((this.formDataList.length-this.waitNum)/this.formDataList.length)*100)}}%</span> |
|
|
|
<h2>此版本为先行体验功能测试版,样式美化和性能优化正在进行中,上传切片文件和合成的完整文件分别再QMPlusserver目录的breakpointDir文件夹和fileDir文件夹</h2> |
|
|
|
>{{Math.floor(((this.formDataList.length-this.waitNum)/this.formDataList.length)*100)}}%</span> --> |
|
|
|
<h2 class="tips">此版本为先行体验功能测试版,样式美化和性能优化正在进行中,上传切片文件和合成的完整文件分别再QMPlusserver目录的breakpointDir文件夹和fileDir文件夹</h2> |
|
|
|
</div> |
|
|
|
</template> |
|
|
|
<script> |
|
|
|
|
|
|
|
import SparkMD5 from 'spark-md5' |
|
|
|
import axios from 'axios' |
|
|
|
import { |
|
|
@ -27,15 +41,25 @@ export default { |
|
|
|
fileMd5: '', |
|
|
|
formDataList: [], |
|
|
|
waitUpLoad: [], |
|
|
|
waitNum: 0 |
|
|
|
waitNum: 0, |
|
|
|
limitFileSize: false, |
|
|
|
percentage:0, |
|
|
|
percentageFlage: true, |
|
|
|
customColor: '#409eff', |
|
|
|
uploadList:[] |
|
|
|
} |
|
|
|
}, |
|
|
|
created(){ |
|
|
|
|
|
|
|
}, |
|
|
|
methods: { |
|
|
|
// 选中文件的函数 |
|
|
|
async choseFile(e) { |
|
|
|
const fileR = new FileReader() // 创建一个reader用来读取文件流 |
|
|
|
const file = e.target.files[0] // 获取当前文件 |
|
|
|
const maxSize = 5*1024*1024 |
|
|
|
this.file = file // file 丢全局方便后面用 可以改进为func传参形式 |
|
|
|
if(file.size<maxSize){ |
|
|
|
fileR.readAsArrayBuffer(file) // 把文件读成ArrayBuffer 主要为了保持跟后端的流一致 |
|
|
|
fileR.onload = async e => { |
|
|
|
// 读成arrayBuffer的回调 e 为方法自带参数 相当于 dom的e 流存在e.target.result 中 |
|
|
@ -83,6 +107,10 @@ export default { |
|
|
|
} |
|
|
|
this.waitNum = this.waitUpLoad.length // 记录长度用于百分比展示 |
|
|
|
} |
|
|
|
} else { |
|
|
|
this.limitFileSize = true |
|
|
|
this.$message('请上传小于5M文件') |
|
|
|
} |
|
|
|
}, |
|
|
|
getFile() { |
|
|
|
// 确定按钮 |
|
|
@ -90,7 +118,14 @@ export default { |
|
|
|
this.$message('请先上传文件') |
|
|
|
return |
|
|
|
} |
|
|
|
this.percentage = Math.floor(((this.formDataList.length-this.waitNum)/this.formDataList.length)*100) |
|
|
|
if(this.percentage == 100){ |
|
|
|
this.percentageFlage = false |
|
|
|
} |
|
|
|
this.sliceFile() // 上传切片 |
|
|
|
if(this.percentage == 100){ |
|
|
|
this.uploadList.push(this.file) |
|
|
|
} |
|
|
|
}, |
|
|
|
sliceFile() { |
|
|
|
this.waitUpLoad && |
|
|
@ -119,7 +154,7 @@ export default { |
|
|
|
fileMd5: this.fileMd5 |
|
|
|
} |
|
|
|
const res = await breakpointContinueFinish(params) |
|
|
|
if (res.code == 0) { |
|
|
|
if (res.success) { |
|
|
|
// 合成文件过后 删除缓存切片 |
|
|
|
const params = { |
|
|
|
fileName: this.file.name, |
|
|
@ -134,7 +169,7 @@ export default { |
|
|
|
} |
|
|
|
</script> |
|
|
|
|
|
|
|
<style scoped> |
|
|
|
<style lang='scss' scoped> |
|
|
|
h3 { |
|
|
|
margin: 40px 0 0; |
|
|
|
} |
|
|
@ -149,4 +184,70 @@ li { |
|
|
|
a { |
|
|
|
color: #42b983; |
|
|
|
} |
|
|
|
</style> |
|
|
|
#fromCont{ |
|
|
|
display: inline-block; |
|
|
|
} |
|
|
|
.fileUpload{ |
|
|
|
padding: 4px 10px; |
|
|
|
height: 20px; |
|
|
|
line-height: 20px; |
|
|
|
position: relative; |
|
|
|
cursor: pointer; |
|
|
|
color: #000; |
|
|
|
border: 1px solid #c1c1c1; |
|
|
|
border-radius: 4px; |
|
|
|
overflow: hidden; |
|
|
|
display: inline-block; |
|
|
|
input{ |
|
|
|
position: absolute; |
|
|
|
font-size: 100px; |
|
|
|
right: 0; |
|
|
|
top: 0; |
|
|
|
opacity: 0; |
|
|
|
cursor: pointer; |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
.fileName{ |
|
|
|
display: inline-block; |
|
|
|
vertical-align: top; |
|
|
|
margin: 6px 15px 0 15px; |
|
|
|
} |
|
|
|
.uploadBtn{ |
|
|
|
position: relative; |
|
|
|
top: -10px; |
|
|
|
margin-left: 15px; |
|
|
|
} |
|
|
|
.tips{ |
|
|
|
margin-top: 30px; |
|
|
|
font-size: 14px; |
|
|
|
font-weight: 400; |
|
|
|
color: #606266; |
|
|
|
} |
|
|
|
.el-divider{ |
|
|
|
margin: 0 0 30px 0; |
|
|
|
} |
|
|
|
|
|
|
|
.list{ |
|
|
|
margin-top:15px; |
|
|
|
} |
|
|
|
.list-item { |
|
|
|
display: block; |
|
|
|
margin-right: 10px; |
|
|
|
color: #606266; |
|
|
|
line-height: 25px; |
|
|
|
margin-bottom: 5px; |
|
|
|
width: 40%; |
|
|
|
.percentage{ |
|
|
|
float: right; |
|
|
|
} |
|
|
|
} |
|
|
|
.list-enter-active, .list-leave-active { |
|
|
|
transition: all 1s; |
|
|
|
} |
|
|
|
.list-enter, .list-leave-to |
|
|
|
/* .list-leave-active for below version 2.1.8 */ { |
|
|
|
opacity: 0; |
|
|
|
transform: translateY(-30px); |
|
|
|
} |
|
|
|
</style> |