js 录音
span{ cursor: pointer; } .audio_list{ margin-top: 10px; } .audio_list audio{ margin-right: 40px; position: relative; } audio span{ color: red; position: absolute; top: 0; bottom: 0; right: -10px; }
js
<div> <span onclick="start()">开始录音</span> <span onclick="stop()">结束录音</span> <div class="audio_list"> </div> </div> <script> const constraints = { audio: true }; var mediaRecorder = null; function start ( ) { if(mediaRecorder){ stop(); return; } var chunks = []; console.log("start") navigator.mediaDevices.getUserMedia(constraints) .then(stream => { mediaRecorder = new MediaRecorder(stream); mediaRecorder.addEventListener('dataavailable', event => { chunks.push(event.data); }); mediaRecorder.addEventListener('stop', () => { const blob = new Blob(chunks, { type: 'audio/wav' }); const url = URL.createObjectURL(blob); console.log(blob, url) const link = document.createElement('a'); link.href = url; link.download = 'recording.wav'; document.body.appendChild(link); link.click(); // 在页面上创建一个音频元素,并设置其源为录音URL var audioElement = document.createElement('audio'); var audio_list = document.querySelector('.audio_list'); audio_list.innerHTML = "" audioElement.src = url; audioElement.controls = true; audio_list.appendChild(audioElement); }); mediaRecorder.start(); }) .catch(err => { console.error(err); }); } function stop ( ) { mediaRecorder.stop(); mediaRecorder = null; console.log("stop" ,mediaRecorder) } </script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?