js 实现录音功能

7 篇文章 0 订阅

问题: 需要前端实现录音功能。

解决方式: 使用 js 自带的 MediaRecorder 实现。

// 预先设置一个变量来存MediaRecorder实例
let mediaRecorder  = null;
// 首先打开麦克风
navigator.mediaDevices.getUserMedia({audio: true}).then(stream=>{
	let chunks = [];
	mediaRecorder = new MediaRecorder(stream);
	mediaRecorder.start();
	
	// 录音开始事件监听(即调用 mediaRecorder.start()时会触发该事件)
	mediaRecorder.onstart = () =>{
        console.log("record start")
    }

	// 录音可用事件监听,发生于mediaRecorder.stop()调用后,mediaRecorder.onstop 前
    mediaRecorder.ondataavailable = (e) =>{
    	console.log("dataavailable")
    	console.log(e)
        chunks.push(e.data)
    }
    
    // 录音结束事件监听,发生在mediaRecorder.stop()和 mediaRecorder.ondataavailable 调用后
    mediaRecorder.onstop = () =>{
    	console.log("record end")
    	// 获取到录音的blob
		let blob = new Blob(chunks,{type:"audio/webm;codecs=opus"}); 
		
		//  将blob转换为file对象,名字可以自己改,一般用于需要将文件上传到后台的情况
		let file = new window.File([blob],"record.webm");
		
		// 将blob转换为地址,一般用于页面上面的回显,这个url可以直接被 audio 标签使用
		let url = (window.URL || webkitURL).createObjectURL(blob);
	}
})

// 录音结束事件,在需要结束录音时调用,录音结束后的操作请在 mediaRecorder.onstop 里面写
mediaRecorder && mediaRecorder.stop()
  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值