news 2026/4/30 14:08:40

前端Vue使用js-audio-plugin实现录音功能

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端Vue使用js-audio-plugin实现录音功能

在前端 Vue 项目中使用 js-audio-recorder 组件,可按以下流程进行操作:

  1. 安装组件:在项目根目录下执行npm i js-audio-recorder命令,安装该组件。
  2. 引入组件:在需要使用录音功能的 Vue 组件中,通过import Recorder from 'js - audio - recorder'引入 Recorder。
  3. 初始化与使用:在组件的created钩子函数或setup函数中初始化 Recorder 实例,并定义相关方法来控制录音操作。

具体使用方法如下:

  • 创建实例:可在created中创建 Recorder 实例,如this.recorder = new Recorder()。也可传入参数自定义采样位数、采样率等,如this.recorder = new Recorder({sampleBits: 16, sampleRate: 16000, numChannels: 1})
  • 开始录音:先通过Recorder.getPermission()获取麦克风权限,成功后调用start方法,如Recorder.getPermission().then(() => {this.recorder.start()})
  • 控制录音:暂停录音调用pause方法,即this.recorder.pause();继续录音调用resume方法,即this.recorder.resume();停止录音调用stop方法,即this.recorder.stop()
  • 播放录音:调用play方法播放录制的音频,如this.recorder.play()
  • 销毁实例:录音结束后,可调用destroy方法销毁实例,释放资源,如this.recorder.destroy()
  • 获取音频数据:可通过getWAVBlob方法获取录制音频的 WAV 格式 Blob 数据,如const blob = this.recorder.getWAVBlob(),用于上传或其他操作。\

示例:

<template> <div> <h1>音频录制示例</h1> <button @click="startRecording" :disabled="isRecording">开始录音</button> <button @click="pauseRecording" :disabled="!isRecording || isPaused">暂停录音</button> <button @click="resumeRecording" :disabled="!isRecording ||!isPaused">继续录音</button> <button @click="stopRecording" :disabled="!isRecording">停止录音</button> <button @click="playRecording" :disabled="!recordingBlob">播放录音</button> <button @click="downloadRecording" :disabled="!recordingBlob">下载录音</button> </div> </template> <script setup> import Recorder from 'js - audio - recorder'; import { ref } from 'vue'; // 录音状态 const isRecording = ref(false); // 暂停状态 const isPaused = ref(false); // 存储录制的音频Blob const recordingBlob = ref(null); let recorder; const startRecording = async () => { try { await Recorder.getPermission(); recorder = new Recorder(); recorder.start(); isRecording.value = true; isPaused.value = false; } catch (error) { console.error('获取权限或开始录音失败', error); } }; const pauseRecording = () => { if (recorder) { recorder.pause(); isPaused.value = true; } }; const resumeRecording = () => { if (recorder) { recorder.resume(); isPaused.value = false; } }; const stopRecording = () => { if (recorder) { recorder.stop(); isRecording.value = false; isPaused.value = false; recordingBlob.value = recorder.getWAVBlob(); recorder.destroy(); } }; const playRecording = () => { if (recordingBlob.value) { const audioUrl = URL.createObjectURL(recordingBlob.value); const audio = new Audio(audioUrl); audio.play(); } }; const downloadRecording = () => { if (recordingBlob.value) { const link = document.createElement('a'); link.href = URL.createObjectURL(recordingBlob.value); link.download ='recording.wav'; link.click(); } }; </script> <style scoped> button { margin: 10px; } </style>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:08:22

解决phpstudy_pro 无法启动 MySQL 以及3306被占用的问题

问题说明 首先我们在启动mysql服务的时候&#xff0c;服务无法启动&#xff0c;而且一直重试。 一、是否真的是端口占用 启动 phpstudy_pro&#xff0c;点击 MySQL 的「启动」按钮&#xff0c;若弹出错误提示&#xff1a; MySQL 启动失败&#xff1a;端口 3306 被占用 或 Po…

作者头像 李华
网站建设 2026/4/27 11:36:03

【synchronized 与 ReentrantLock + Condition 的深度对比 Plus版】

Java并发编程&#xff1a;synchronized 与 ReentrantLock Condition 的深度对比——从Monitor队列到惊群效应与精确唤醒前言正文一、每个Java对象天生都能当锁&#xff1f;Monitor的底层结构形象比喻&#xff1a;锁对象就像一个会议室。关键区别&#xff1a;二、synchronized的…

作者头像 李华
网站建设 2026/4/30 0:16:41

基于单片机的智能窗帘控制系统设计与实现

一、设计背景与核心需求 随着智能家居技术的发展&#xff0c;传统窗帘的手动操作已无法满足现代生活对便捷性、舒适性和节能性的需求。高层住宅大尺寸窗帘拉动费力、忘记关窗导致风雨侵入、光照过强影响室内环境等问题频发。基于单片机的智能窗帘控制系统&#xff0c;通过环境感…

作者头像 李华
网站建设 2026/4/22 1:41:15

Java 应用提供对接第三方接口的优雅高级写法

一、真正的高手,不是“调通接口”,而是“设计边界” 对接第三方接口,看似只是发个请求、拿个 JSON,但背后其实是——系统边界的协作与防御设计。 你面对的不是自己可控的代码,而是一个随时可能“变脸”的外部世界: 对方文档写着“此字段必传”,实际却返回 null 测试环境…

作者头像 李华
网站建设 2026/4/20 18:06:32

基于S7 - 1200 PLC的工业冷库等控制系统漫谈

基于S7-1200 PLC工业冷库控制系统 基于PLC的空调控制系统设计。 基于PLC的工业空调机组设计。基于PLC的冷风机组系统设计带解释的梯形图接线图原理图图纸&#xff0c;io分配&#xff0c;组态画面在工业领域&#xff0c;对于温度的精准控制至关重要&#xff0c;无论是冷库、空调…

作者头像 李华
网站建设 2026/4/25 0:12:20

鸿蒙Electron应用商业化效果评估:数据驱动的增长闭环

基于前文对商业化落地的探讨&#xff0c;本次将聚焦“鸿蒙Electron应用商业化效果评估体系”&#xff0c;从“核心指标构建、数据采集分析、优化迭代闭环”三个维度&#xff0c;提供可量化、可落地的评估方案&#xff0c;帮助开发者精准判断商业化健康度并高效优化。 鸿蒙Elect…

作者头像 李华