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}`);

      // 开始字节
      const start = currentChunk * chunkSize;
      // 结束字节
      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.效果图
 

非常简单(。・ω・。) 

相关推荐

  1. 文件分块

    2024-01-23 02:56:02       30 阅读
  2. 文件实现

    2024-01-23 02:56:02       28 阅读
  3. Vue+Django文件

    2024-01-23 02:56:02       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-23 02:56:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-23 02:56:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-23 02:56:02       82 阅读
  4. Python语言-面向对象

    2024-01-23 02:56:02       91 阅读

热门阅读

  1. 超分之SRGAN官方代码解读

    2024-01-23 02:56:02       52 阅读
  2. datawhale 第三章-模型架构

    2024-01-23 02:56:02       55 阅读
  3. lambda

    lambda

    2024-01-23 02:56:02      55 阅读
  4. 【Python机器学习】无监督学习(理论知识)

    2024-01-23 02:56:02       55 阅读
  5. 【Vue3+Ts项目】硅谷甄选 — 菜单权限+按钮权限

    2024-01-23 02:56:02       58 阅读
  6. c# openxml 删除xlsx、xls的外链

    2024-01-23 02:56:02       55 阅读
  7. 服务限流实现方案

    2024-01-23 02:56:02       54 阅读
  8. SpringBoot连接mysql数据库相关配置(druid连接池)

    2024-01-23 02:56:02       58 阅读