欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue+ts大文件切片上傳的實現示例

 更新時間:2024年01月23日 08:39:33   作者:西湖龍井君  
在Vue項目中,大圖片和多數據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;
    // 切片數量
    const chunks = Math.ceil(file.size / chunkSize);
    // 當前切片下標
    let currentChunk = 0;
    // SparkMD5 實例
    const spark = new SparkMD5.ArrayBuffer();
    // fileReader 實例
    const fileReader = new FileReader();

    // 讀取成功
    fileReader.onload = function () {
      // 讀取到的內容
      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é)
      const end =
        start + chunkSize >= file.size ? file.size : start + chunkSize;
      // 切片
      const chunk = file.slice(start, end);
      // 將 chunk 追加到 chunkLish 中
      chunkLish.push(chunk);
      // 讀取該切片的內容
      fileReader.readAsArrayBuffer(chunk);
    }
    // 默認調用一次 loadNext
    loadNext();
  });
}

3.效果圖

總結

到此這篇關于vue+ts大文件切片上傳的實現示例的文章就介紹到這了,更多相關vue ts大文件切片上傳內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue前端HbuliderEslint實時校驗自動修復設置

    vue前端HbuliderEslint實時校驗自動修復設置

    這篇文章主要為大家介紹了vue前端中Hbulider中Eslint實時校驗自動修復設置操作過程,有需要的朋友可以借鑒參考下希望能夠有所幫助
    2021-10-10
  • Vue3頁面數據加載延遲的問題分析和解決方法

    Vue3頁面數據加載延遲的問題分析和解決方法

    在?Vue?3?的項目中,當我們使用響應式數據(如?ref?或?computed)來管理頁面狀態(tài)時,可能會遇到由于接口數據加載延遲,導致頁面初始渲染時數據尚未獲取完成的問題,本文針對此問題簡單分析了原因和解決方法,需要的朋友可以參考下
    2024-11-11
  • vue.js+Element實現表格里的增刪改查

    vue.js+Element實現表格里的增刪改查

    本篇文章主要介紹了vue.js+Element實現增刪改查,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • vue-dplayer 視頻播放器實例代碼

    vue-dplayer 視頻播放器實例代碼

    今天小編就為大家分享一篇vue-dplayer 視頻播放器實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 十分鐘封裝一個好用的axios步驟示例

    十分鐘封裝一個好用的axios步驟示例

    這篇文章主要為大家介紹了十分鐘封裝一個好用的axios步驟示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 解決vue自定義指令導致的內存泄漏問題

    解決vue自定義指令導致的內存泄漏問題

    這篇文章主要介紹了解決vue自定義指令導致的內存泄漏問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue.js實現的綁定class操作示例

    vue.js實現的綁定class操作示例

    這篇文章主要介紹了vue.js實現的綁定class操作,結合實例形式分析了vue.js綁定class常見的3種操作技巧,需要的朋友可以參考下
    2018-07-07
  • 深入探究Vue中探究組合式API的奧秘

    深入探究Vue中探究組合式API的奧秘

    Vue?3中引入了組合式API,它是一種新的代碼組織方式,旨在讓開發(fā)者更靈活地組織和重用Vue組件的邏輯,下面我們就來學習一下Vue中常見組合式API的使用吧
    2023-11-11
  • 從0搭建Vue3組件庫如何使用?glup?打包組件庫并實現按需加載

    從0搭建Vue3組件庫如何使用?glup?打包組件庫并實現按需加載

    這篇文章主要介紹了從0搭建Vue3組件庫如何使用?glup?打包組件庫并實現按需加載,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • vue?filter的幾種用法示例小結

    vue?filter的幾種用法示例小結

    Vue.filter函數用于注冊一個全局的過濾器,該過濾器可以在模板和組件中使用,這篇文章主要介紹了vue?filter的幾種用法示例小結,需要的朋友可以參考下
    2024-08-08

最新評論