我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何用JavaScript让你的浏览器说话

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何用JavaScript让你的浏览器说话

1. 最简单的例子

让我们来创建一个基础函数,这个函数的参数为我们想说的话或者词,最后让我们的浏览器说出来。我们将利用在大多数现代浏览器上都可以使用的原生APIspeechSyntehsis。


function speak(sentence) {
    const utterance = new SpeechSynthesisUtterance(sentence)
    window.speechSynthesis.speak(utterance)
}

// test
speak('hello world');

信不信由你,以上的代码就是让大部分浏览器说出一句话所需要的一切!让我们来看看这里具体发生了什么。

我们创建的speak()函数,该函数以词句为参数。我们创建了一个发声对象,他实际上是一个语言请求对象,其中包含了有关说什么和如何说相关的所有数据。

2. 自定义语速和音调

让我们做一个稍微复杂一点的示例,尝试修改说出来的单词的速度和音调。



function speak(sentence, pitch, rate) {
    const utterance = new SpeechSynthesisUtterance(sentence)

    utterance.rate = rate
    utterance.pitch = pitch

    window.speechSynthesis.speak(utterance)
}

在上面的示例中,我们基于原来函数增加了音调和语速2个参数。在我们创建了发声对象之后,我们可以直接在发声对象上直接修改某些属性。但是,目前还不能通过构造函数或者setter方法来修改。

pitch(音调)是一个浮点数,取值范围是0到2,默认值是1。这个值的效果可能受到引擎或者声音的限制。

rate(语速)是一个浮点数,取值范围是0.1到10,默认值是1。

现在,如果我们使用简单的句子调用上面的代码,我们的浏览器就会以正常的语速和音调说出下面的话:


speak('Hello world', 1, 1)

3. 怎么调整音量

我们也可以像调整音调和速度一样调整音量,让我们来快速了解一下如何实现



function speak(sentence, volume) {
    const utterance = new SpeechSynthesisUtterance(sentence)

    utterance.volume = volume

    window.speechSynthesis.speak(utterance)
}

修改之前的代码,我们现在传入音量参数。音量也是一个浮点数,取值范围0到1,默认值是0.5。

同样,目前没有办法通过构造函数或者setter方法来设置音量。现在,我们给这个函数传入自己想要的句子和音量就能听到想要的结果了。

4. 常用的函数

speechSynthesis对象有一些可以派得上用场的函数。我们可以暂停、恢复、甚至取消语言的进度。让我们快速浏览一下:


const utterance = new SpeechSynthesisUtterance('Hello world');
window.speechSynthesis.speak(utterance);

// 暂停 
window.speechSynthesis.pause();
// 恢复
window.speechSynthesis.resume();
// 取消
window.speechSynthesis.cancel();

上面的代码将会说出我们想要的句子,并且这段语音会暂停、恢复,最终取消。你也可以在你的浏览器里面试一试上面的代码。

我们也可以通过speechSynthesis对象上的paused属性来直接判断该段音频是否被暂停,它将会返回一个布尔值来表示该段音频是否被暂停了。


window.speechSynthesis.paused // Boolean

如果还有一些积压的等待读出来的句子怎么办?嗯,还有一个属性pending,用来检查是否有任何等待说出来的语音。它返回一个布尔值,指示是否有待处理的语音。


const utterThis = new SpeechSynthesisUtterance('Hello world');
const utterThat = new SpeechSynthesisUtterance('Hello JavaScript');

window.speechSynthesis.speak(utterThis);
window.speechSynthesis.speak(utterThat);
window.speechSynthesis.pending;

执行上面的代码时,将会有两段语音排队,并且他们会按照顺序播放。当我们获取pending属性时,这个值将返回true,因为,有第二段语音在等待播放。

注意:如果你只有一段语音,这个pending属性将会一直返回false,因为没有排队等待播放的语音。

5. 事件监听

当我们使用SpeechSynthesisUtteranceapi时,我们可以监听几个比较有用的事件。让我们一起看一下:


const utterance = new SpeechSynthesisUtterance('Hello world')

utterance.addEventListener('start', () => console.log('Utterance start'))
utterance.addEventListener('pause', () => console.log('Utterance paused'))
utterance.addEventListener('resume', () => console.log('Utterance resumed'))
utterance.addEventListener('end', () => console.log('Utterance end'))

window.speechSynthesis.speak(utterance)

6. 总结

希望这篇文章足以让你在浏览器里面玩转“合成语音”啦!你现在应该掌握了如何开始,停止和暂停语音,以及调整语音的速率,音调和音量。

以上就是如何用JavaScript让你的浏览器说话的详细内容,更多关于JavaScript的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何用JavaScript让你的浏览器说话

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么使用JavaScript让你的浏览器说话

这篇文章主要介绍怎么使用JavaScript让你的浏览器说话,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!javascript是一种什么语言javascript是一种动态类型、弱类型的语言,基于对象和事件驱动并具有相
2023-06-14

JavaScript BOM:让浏览器为你所用

浏览器的强大助手:深入了解 JavaScript BOM
JavaScript BOM:让浏览器为你所用
2024-03-05

JavaScript BOM:让你的网站成为浏览器的宠儿

总结:JavaScript BOM,全称是 Browser Object Model,为 JavaScript 的 Window 对象提供了多种控制浏览器窗口的方法,可以帮助你创建更加丰富、交互性更强的网页。 JavaScript BOM, Window 对象,浏览器窗口,交互性网页
JavaScript BOM:让你的网站成为浏览器的宠儿
2024-02-22

JavaScript BOM 实战指南:让浏览器听你的指挥

浏览器操作模型 (BOM) 是 JavaScript 的一个强大工具,它允许 Web 开发人员与浏览器进行交互,从而实现各种有用的功能。本文将提供一个全面的指南,演示如何利用 BOM 来控制浏览器行为,让 Web 应用程序更加交互和响应。
JavaScript BOM 实战指南:让浏览器听你的指挥
2024-03-05

JavaScript BOM:让你的网页与浏览器亲密无间

JavaScript 的 BOM 对象是 JavaScript 中最强大的对象之一,它可以让你访问和控制浏览器的许多特性,例如地址栏、历史记录、窗口、屏幕等等。通过使用 BOM 对象,你可以让你的网页与浏览器进行亲密无间地互动,从而给用户带来更好的体验。
JavaScript BOM:让你的网页与浏览器亲密无间
2024-02-22

如何使用JavaScript检测当前浏览器是无头浏览器

这篇文章将为大家详细讲解有关如何使用JavaScript检测当前浏览器是无头浏览器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。javascript是一种什么语言javascript是一种动态类型、弱类型
2023-06-14

如何打开浏览器的JavaScript支持

随着互联网技术的不断发展,网站变得越来越复杂,JavaScript也成为现代网站开发的一个重要组成部分。但是,在浏览网站时,有些人可能会遇到浏览器不支持JavaScript的情况。那么,如何打开浏览器的JavaScript支持呢?1. 检查浏览器版本在打开JavaScript之前,首先需要执行一些检查。最重要的是,请确保您的浏览器版本是最新的。许多浏览器在更新版本后会默认开启J
2023-05-14

如何分析针对HTTPS浏览器会话的攻击

如何分析针对HTTPS浏览器会话的攻击,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。关于SSL网站的好消息就是:大多数SSL网站都运行着强大的加密技术。坏消息就是:超过60%的
2023-06-12

javascript中浏览器是如何看闭包的

小编给大家分享一下javascript中浏览器是如何看闭包的,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言闭包,是javascript的一大理解难点,网上关于
2023-06-25

JavaScript浏览器的兼容问题如何解决

本文小编为大家详细介绍“JavaScript浏览器的兼容问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript浏览器的兼容问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1、i
2023-07-04

如何按照字体名称调用字体让浏览器显示你希望的字体

本篇内容介绍了“如何按照字体名称调用字体让浏览器显示你希望的字体”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!第1个问题:你如何指示浏览器显
2023-06-08

如何让网页自动调用双核浏览器的极速模式

本篇内容介绍了“如何让网页自动调用双核浏览器的极速模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在head标签中添加一行代码: XML/
2023-06-08

如何使用JavaScript实现手机端判断浏览器类型

这篇文章主要介绍如何使用JavaScript实现手机端判断浏览器类型,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!手机端判断浏览器类型BrowserInfo = { isAndroid: Boolean
2023-06-20

编程热搜

目录