通过FileReader API获取上传音频的长度

前言

FileReader 接口允许 Web 应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 FileBlob 对象指定要读取的文件或数据。

实现

调用FileReader API,并通过(window.AudioContext || window.webkitAudioContext)()创建音频上下文对象实现

代码示例

关键代码

复制代码
const customRequest = (file) => {
  //创建FileReader
  const fileReader = new FileReader();
  //读取成功完成时触发
  fileReader.onload = (event) => {
    const arrayBuffer = event.target.result;
    //创建音频上下文对象
    const audioContext = new (window.AudioContext ||
      window.webkitAudioContext)();
    audioContext.decodeAudioData(arrayBuffer, async (buffer) => {
      const duration = Math.floor(buffer.duration); // 获取音频时长
      console.log("音频时长:", duration);
      //下面可做对音频时长限制的操作
    });
  };
  //当读取由于错误而失败时触发。
  fileReader.onerror = (error) => {
    console.error("Error reading file:", error);
  };
  //开始读取指定的 Blob 中的内容,读取完成,result 属性中将包含一个表示文件数据的 ArrayBuffer 对象
  fileReader.readAsArrayBuffer(file);
};

注意:最后一定要记得调用readAsArrayBuffe来读取内容,不然获取不到FileReader的上下文。

相关推荐
苕皮蓝牙土豆几秒前
C++ map容器: 插入操作
开发语言·c++
Dxy12393102165 分钟前
Python 装饰器详解
开发语言·python
linab11212 分钟前
mybatis中的resultMap的association及collectio的使用
java·开发语言·mybatis
NaclarbCSDN31 分钟前
Java IO框架
开发语言·python
fanTuanye33 分钟前
Java基础知识总结(超详细整理)
java·开发语言
顾子茵37 分钟前
c++从入门到精通(六)--特殊工具与技术-完结篇
android·开发语言·c++
孞㐑¥40 分钟前
Linux之基础IO
linux·开发语言·c++·经验分享·笔记
进取星辰42 分钟前
31、魔法生物图鉴——React 19 Web Workers
开发语言·javascript·ecmascript
mahuifa1 小时前
ubuntu18.04编译qt5.14.2源码
开发语言·数据库·qt
一个Potato1 小时前
Python面试总结
开发语言·python