Chrome桌面端可直接用SpeechRecognition,但需HTTPS或localhost;Safari和Firefox完全不支持;无有效polyfill;最小可用需检测兼容性、设lang为zh-CN、interimResults为true并监听onresult事件。
SpeechRecognition 在 Chrome 中能用吗?不能直接用——SpeechRecognition 接口虽是 HTML5 Web Speech API 的一部分,但目前仅 Chromium 内核浏览器(Chrome、Edge)在桌面端默认启用,且必须通过 HTTPS 或 localhost 访问。HTTP 页面会静默失败,控制台通常只报 TypeError: SpeechRecognition is not a constructor,不提示原因。
typeof SpeechRecognition !== 'undefined' 为 false
核心是初始化 SpeechRecognition 实例并监听事件,不是调用某个函数就能出结果。关键步骤缺一不可:
const SpeechRecognition = window.SpeechRecognition || window.webkitSpeechRecognition;
recognition.continuous = false(默认为 false,但建议写明)和 recognition.interimResults = true(否则只返回最终结果,无实时反馈)recognition.lang = 'zh-CN' 必须显式指定,否则可能按浏览器语言 fallback,中文识别率骤降recognition.start() 后,用户需在 1 秒内开始说话,否则自动终止;中途静音超 5 秒也会结束const recognition = new (window.SpeechRecognition || window.webkitSpeechRecognition)();
recognition.lang = 'zh-CN';
recognition.interimResults = true;
recognition.onresult = event => {
const transcript = Array.from(event.results)
.map(result => result[0].transcript)
.join('');
console.log(transcript); // 实时文本在这里
};
recognition.start();
onend 频繁触发,但没识别到文字?这是最常被忽略的交互陷阱:onend 触发不代表识别完成,它只表示本次录音会话结束——可能是用户停顿、网络抖动、权限被拒,甚至只是后台标签页被切换导致音频输入中断。
onend 里自动调用 start(),否则可能无限重试,触发浏览器频率限制onresult 事件中 event.results.length > 0 且 result.isFinal === true
onresult 的 final 结果处理完后,再调用一次 start(),并加防抖(例如延迟 300ms)onerror 会抛出 error:not-allowed,此时应引导用户手动点击麦克风图标重新授权如果项目必须支持 Safari、Firefox 或生产环境 HTTPS 不可控,就别硬扛 Web Speech API。真实项目中更可行的是:
MediaRecorder API),把音频 Blob 上传到后端
Web Speech API 适合原型验证或内部工具,但凡涉及用户交付,就
