github地址git
結合elemenet-ui 支持分片上傳github
暫時不支持安裝的方式, 主要是提供思路, 能夠複製代碼去使用(代碼邏輯還能夠繼續優化)bash
const readFileMD5 = (files) => {
// 讀取每一個文件的md5
files.map((file, index) => {
let fileRederInstance = new FileReader()
fileRederInstance.readAsBinaryString(file)
fileRederInstance.addEventListener('load', e => {
let fileBolb = e.target.result
let fileMD5 = md5(fileBolb)
if (!fileList.some((arr) => arr.md5 === fileMD5)) {
fileList.push({md5: fileMD5, name: file.name, file})
AllFileSize = AllFileSize + file.size
}
if (index === files.length - 1) readChunkMD5(fileList)
}, false)
})
}
複製代碼
// 針對每一個文件進行chunk處理
const readChunkMD5 = (fileList) => {
fileList.map((currentFile, fileIndex) => {
const chunkSize = pieceSize * 1024 * 1024 // 5MB一片
const chunkCount = Math.ceil(currentFile.file.size / chunkSize) // 總片數
AllChunk = AllChunk + chunkCount // 計算全局chunk數
// let fileSize = currentFile.file.size // 文件大小
// 針對單個文件進行chunk上傳
for (var i = 0; i < chunkCount; i++) {
const { chunk } = getChunkInfo(currentFile.file, i, chunkSize)
let chunkFR = new FileReader()
chunkFR.readAsBinaryString(chunk)
chunkFR.addEventListener('load', e => {
let chunkBolb = e.target.result
let chunkMD5 = md5(chunkBolb)
this.readingFile = false
uploadChunk(currentFile, {chunkMD5, chunk, currentChunk: i, chunkCount}, fileIndex)
}, false)
}
})
}
複製代碼
const uploadChunk = (currentFile, chunkInfo, fileIndex) => {
let fetchForm = new FormData()
fetchForm.append('file_name', currentFile.name)
fetchForm.append('md5', currentFile.fileMD5)
fetchForm.append('data', chunkInfo.chunk)
fetchForm.append('chunks', chunkInfo.chunkCount)
fetchForm.append('chunk_index', chunkInfo.currentChunk)
fetchForm.append('chunk_md5', chunkInfo.chunkMD5)
fetch({
type: 'post',
url: chunkUrl,
data: fetchForm
}).then(res => {
progressFun()
// currentAllChunk++
if (chunkInfo.currentChunk < chunkInfo.chunkCount - 1) {
successAllCount++
} else {
// 當總數大於等於分片個數的時候
if (chunkInfo.currentChunk >= chunkInfo.chunkCount - 1) {
uploadFile(currentFile, fileIndex)
}
}
}).catch((e) => {
error && error(e)
})
}
複製代碼
// 對分片已經處理完畢的文件進行上傳
const uploadFile = (currentFile) => {
let makeFileForm = new FormData()
makeFileForm.append('md5', currentFile.fileMD5)
makeFileForm.append('file_name', currentFile.name)
fetch({ // 合併文件
type: 'post',
url: fileUrl,
data: makeFileForm
}).then(res => {
progressFun()
res.file_name = currentFile.name
success && success(res)
successAllCount++
}).catch(e => {
error && error(e)
})
}
複製代碼
注意app
這裏的上傳是並行的,若是要串行須要改造代碼函數