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