0

0

JavaScript语音识别与合成

betcha

betcha

发布时间:2025-10-25 22:27:01

|

582人浏览过

|

来源于php中文网

原创

答案:JavaScript通过Web Speech API实现语音识别与合成。使用SpeechRecognition将语音转文本,需在安全上下文并获麦克风权限;利用SpeechSynthesis将文本转语音,可设置语速、音调等参数。两者结合可用于语音助手、无障碍阅读等场景,但语音识别兼容性有限,主要支持Chrome和Edge,而合成功能普遍可用。

javascript语音识别与合成

JavaScript 实现语音识别与语音合成,主要依赖浏览器提供的 Web APIs。目前主流支持的是 Web Speech API,它包含两个核心部分:SpeechRecognition(语音识别)和 SpeechSynthesis(语音合成)。下面分别介绍它们的使用方法和注意事项。

语音识别(SpeechRecognition)

语音识别功能允许用户通过说话将语音转换为文本。该功能依赖于 SpeechRecognition 或其前缀版本 webkitSpeechRecognition,因为目前大多数浏览器仅支持带前缀的实现。

基本用法:

Reecho睿声
Reecho睿声

Reecho AI:超拟真语音合成与瞬时语音克隆平台

下载
  • 创建识别实例,并设置相关参数
  • 监听识别结果事件
  • 启动识别
// 示例代码
const recognition = new (window.SpeechRecognition || window.webkitSpeechRecognition)();
recognition.lang = 'zh-CN'; // 设置语言
recognition.interimResults = false; // 是否返回中间结果
recognition.continuous = false; // 是否持续监听

recognition.onresult = function(event) {
  const transcript = event.results[0][0].transcript;
  console.log('识别结果:', transcript);
};

recognition.onerror = function(event) {
  console.error('识别出错:', event.error);
};

// 开始识别
recognition.start();

注意:语音识别需要在安全上下文中运行(即 HTTPS 或 localhost),且用户需授权麦克风权限。某些浏览器(如 Chrome)可能将此功能限制为仅在用户交互后调用(例如点击按钮触发 start())。

立即学习Java免费学习笔记(深入)”;

语音合成(SpeechSynthesis)

语音合成功能可将文本转换为语音朗读出来,使用的是 window.speechSynthesis 接口,兼容性较好。

基本用法:

  • 创建一个 SpeechSynthesisUtterance 实例
  • 设置语音参数(如语速、音调、语言、声音等)
  • 调用 speechSynthesis.speak() 播放
// 示例代码
const utterance = new SpeechSynthesisUtterance('你好,这是语音合成示例');
utterance.lang = 'zh-CN';
utteraence.rate = 1;   // 语速,0.1 到 10
utterance.pitch = 1;   // 音调,0 到 2
utterance.volume = 1;  // 音量,0 到 1

// 可选:选择特定声音
const voices = window.speechSynthesis.getVoices();
if (voices.length > 0) {
  utterance.voice = voices[0];
}

window.speechSynthesis.speak(utterance);

提示:在页面加载初期,getVoices() 可能返回空数组,建议延迟获取或监听 voiceschanged 事件。

speechSynthesis.onvoiceschanged = function() {
  const voices = speechSynthesis.getVoices();
  console.log('可用声音:', voices);
};

实际应用场景

结合语音识别与合成,可以构建简单的语音助手、语音输入表单、无障碍阅读等功能。

  • 用户说话 → 识别成文本 → 系统处理 → 合成语音回复
  • 网页内容高亮朗读(点击段落自动播放)
  • 语音控制界面操作(如“打开菜单”、“搜索XX”)

这类功能适合教育、辅助工具、智能客服等场景,但需考虑环境噪音、口音识别准确率等问题。

兼容性与限制

目前 Web Speech API 的支持情况如下:

  • 语音识别:Chrome、Edge 支持较好;Firefox、Safari 不支持或需手动开启
  • 语音合成:现代浏览器普遍支持,包括移动端

不支持的浏览器可通过第三方服务(如 Google Cloud Speech-to-Text / Text-to-Speech)配合后端中转实现,但会增加复杂度和成本。

基本上就这些。只要掌握 SpeechRecognition 和 SpeechSynthesis 的基本用法,就能在项目中快速集成语音交互能力。注意权限、安全性与用户体验即可。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

831

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

743

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1415

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

381

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

940

2025.04.24

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1126

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

192

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1618

2025.12.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号