前端文件转[byte 数组]形式

这段代码定义了一个名为`file2Uint8Array`的公共方法,用于将上传的文件转换为Uint8Array类型。它通过FileReader API读取文件内容,然后将结果转换为Uint8Array数组。在调用此方法时,可以获取到文件的byte数组,并进一步用于数据导入操作。在示例中,这个方法被用于处理多个文件的上传,将每个文件转换后的结果存储在一个数组中,然后调用后台API进行解析导入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

定义一个公共方法:

export const file2Uint8Array = (file) => new Promise((resolve) => {
//file 为上传文件
  const reader = new FileReader();
  reader.readAsArrayBuffer(file);
  reader.onload = function () {
    const bytes = new Uint8Array(this.result);
    const bytesArray = [];
    for (let i = 0; i < bytes.length; i++) {
      bytesArray.push(bytes[i]);
    }
    resolve(bytesArray);
  };
});

在对应的页面引入:

import { file2Uint8Array } from '@/utils';

调用该方法返回对应的byte数组:

const handleImport = async () => {
  // let array = [];
  // for (const file of formState.fileList) {
  //   const res = await file2Uint8Array(file.originFileObj);
  //   array.push(res);
  // }
  // console.log(array);

  // 上面是多个文件解析上传,返回array数组里面对应上传文件

  const dataBlod = await file2Uint8Array(formState.fileList[0].originFileObj);
  // dataBlod为返回的byte数组
  const obj = {
    data: dataBlod,
    filename: formState.fileList[0].name,
    method: formState.value
  };
  if (dataBlod.length > 0) {
    apis.domain
      .resolverImport(appStore.rowAnalytic.id, { ...obj })
      .then((res) => {
        emit('parse-import', res.batchOperationLogId);
      })
      .finally(() => {});
  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值