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.效果图
 

非常简单(。・ω・。) 

  • 13
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue3中使用TypeScript进行多文件上传,你可以按照以下步骤进行操作: 1. 首先,创建一个文件上传组件。你可以使用`custom-upload`组件,并通过`v-model`绑定一个表单项,用于存储上传文件列表。在`<script>`标签中,引入需要的接口类型和API封装方法。 ```javascript <template> <custom-upload v-model="formInline.attachmentResultList" :attr="attrResult" /> </template> <script> import { ref } from 'vue'; // 引入Vue3的ref方法 import { uploadFile } from '@/api'; export default { setup() { const formInline = ref({ attachmentResultList: [] }); const attrResult = ref({ id: 'fileUploadId', name: 'attachmentName', limit: 999, readonly: true }); return { formInline, attrResult }; } }; </script> ``` 2. 在API文件中,定义多文件上传的方法`uploadFile`。该方法接收一个`FormData`类型的参数,用于包含上传文件数据。通过调用`http.upload`方法,并指定上传文件的URL路径和请求头,实现文件上传功能。 ```javascript // api.ts import http from '@/api'; import { UPLOAD_FILE } from '@/api/config/servicePort'; export const uploadFile = (params: FormData) => { return http.upload<Upload.ResFileList>(UPLOAD_FILE + '/file/uploadFile', params, { headers: { 'Content-Type': 'multipart/form-data' } }); }; ``` 3. 定义文件上传的接口类型。根据你的需求,可以根据接口返回的数据定义相应的类型。 ```javascript // interface.ts export namespace Upload { export interface ResFileList { id: string; fileName: string; fileUrl: string; uploadTime: string; operator: string; fileType: string; fileSize: number; fileOldname: string; } } ``` 通过上述步骤,你就可以在Vue3中使用TypeScript实现多文件上传的功能了。在你的组件中,用户可以选择多个文件进行上传,并且上传成功后,文件相关的信息将会被保存在`formInline.attachmentResultList`中,你可以根据业务需求进行进一步处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值