vue+ts大文件切片上傳的實(shí)現(xiàn)示例
別看文字了,看代碼注釋吧§(* ̄▽ ̄*)§
1. src 下 的.vue 文件 src/APP.vue
# src/APP.vue
<template>
<div>
<input type="file" @change="onChange">
</div>
</template>
<script setup lang="ts">
import { getFileChunksAndHash } from './utils';
const onChange = (event: Event) => {
// 文件
const file = (event.target as HTMLInputElement).files?.[0]!
getFileChunksAndHash(file).then((result) => {
console.log("chunkList", result.chunkLish);
console.log("hash", result.hash);
}).catch((error: Error) => {
console.log("失敗", error);
})
}
</script>2. src下文件夾,與上方??代碼在同一目錄 src/utils/index.ts
# src/utils/index.ts
import SparkMD5 from "spark-md5";
// 讀取所有切片和hash
export function getFileChunksAndHash(
file: File
): Promise<{ chunkLish: Blob[]; hash: string }> {
console.time("computed");
return new Promise((resolve, reject) => {
// 切片集合
const chunkLish: Blob[] = [];
// 切片大小
const chunkSize = 1024 * 1024 * 2;
// 切片數(shù)量
const chunks = Math.ceil(file.size / chunkSize);
// 當(dāng)前切片下標(biāo)
let currentChunk = 0;
// SparkMD5 實(shí)例
const spark = new SparkMD5.ArrayBuffer();
// fileReader 實(shí)例
const fileReader = new FileReader();
// 讀取成功
fileReader.onload = function () {
// 讀取到的內(nèi)容
const result = this.result as ArrayBuffer;
// 將 result 追加到 計(jì)算hash 的操作中
spark.append(result);
// console.log("result", result);
currentChunk++;
if (currentChunk < chunks) {
loadNext();
} else {
const hash = spark.end();
console.timeEnd("computed");
// console.log("hash為:", hash);
// 讓 promise 完成
resolve({
chunkLish,
hash,
});
}
};
// 讀取失敗
fileReader.onerror = function (error) {
// console.log("失敗", error);
reject(error);
};
// 定義一個(gè) loadNext 方法
function loadNext() {
// console.log(`read ${currentChunk + 1} of ${chunks}`);
// 開始字節(jié)
const start = currentChunk * chunkSize;
// 結(jié)束字節(jié)
const end =
start + chunkSize >= file.size ? file.size : start + chunkSize;
// 切片
const chunk = file.slice(start, end);
// 將 chunk 追加到 chunkLish 中
chunkLish.push(chunk);
// 讀取該切片的內(nèi)容
fileReader.readAsArrayBuffer(chunk);
}
// 默認(rèn)調(diào)用一次 loadNext
loadNext();
});
}
3.效果圖

總結(jié)
到此這篇關(guān)于vue+ts大文件切片上傳的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)vue ts大文件切片上傳內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue前端HbuliderEslint實(shí)時(shí)校驗(yàn)自動(dòng)修復(fù)設(shè)置
這篇文章主要為大家介紹了vue前端中Hbulider中Eslint實(shí)時(shí)校驗(yàn)自動(dòng)修復(fù)設(shè)置操作過程,有需要的朋友可以借鑒參考下希望能夠有所幫助2021-10-10
Vue3頁(yè)面數(shù)據(jù)加載延遲的問題分析和解決方法
在?Vue?3?的項(xiàng)目中,當(dāng)我們使用響應(yīng)式數(shù)據(jù)(如?ref?或?computed)來管理頁(yè)面狀態(tài)時(shí),可能會(huì)遇到由于接口數(shù)據(jù)加載延遲,導(dǎo)致頁(yè)面初始渲染時(shí)數(shù)據(jù)尚未獲取完成的問題,本文針對(duì)此問題簡(jiǎn)單分析了原因和解決方法,需要的朋友可以參考下2024-11-11
vue.js+Element實(shí)現(xiàn)表格里的增刪改查
本篇文章主要介紹了vue.js+Element實(shí)現(xiàn)增刪改查,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
vue.js實(shí)現(xiàn)的綁定class操作示例
這篇文章主要介紹了vue.js實(shí)現(xiàn)的綁定class操作,結(jié)合實(shí)例形式分析了vue.js綁定class常見的3種操作技巧,需要的朋友可以參考下2018-07-07
從0搭建Vue3組件庫(kù)如何使用?glup?打包組件庫(kù)并實(shí)現(xiàn)按需加載
這篇文章主要介紹了從0搭建Vue3組件庫(kù)如何使用?glup?打包組件庫(kù)并實(shí)現(xiàn)按需加載,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03

