23 Speech Synthesis 中文指南

本篇作者:©大史快跑Dashrun——Chinasoft Frontend Developer

简介:JavaScript30Wes Bos 推出的一个 30 天挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。目的是帮助人们用纯 JavaScript 来写东西,不借助框架和库,也不使用编译器和引用。现在你看到的是这系列指南的第 23 篇。完整指南在 GitHub,喜欢请 Star 哦♪(^∇^*)

创建时间:2017-09-20
最后更新:2017-09-22

挑战任务

初始文档index-start.html提供了一个阅读器,你需要完成如下编程任务:
1.使用相应的WebAPI接口获得浏览器支持的语言种类列表,并填充至页面的下拉菜单中,选择中文;
2.在文本域中输入对应语言的文字,点击speak按钮后浏览器会阅读输入的文字;
3.在浏览器阅读时,点击stop按钮,浏览器会停止阅读;
4.拖动ratepitch滑块可改变阅读速度和音高。

实现效果

结果展示

相关知识

1.SpeechSynthesisUtterance接口
本接口用于设置阅读器阅读的配置参数,包括语言,阅读速度,语调等,实例化SpeechSynthesisUtterance后,可以通过为其属性赋值来完成参数配置,详细信息请直接参考MDN中的SpeechSynthesisUtterance接口说明
2.SpeechSynthesis接口
本接口用于控制阅读器行为,包括获取浏览器支持的朗读语言,文本朗读,暂停,停止等,接口属性中定义有paused,speaking等只读属性来表明当前的状态,详细使用方式请参考MDN中的SpeechSynthesis接口说明

编程思路

  1. 本次编程任务使用相应接口的最基本功能即可实现,编程中根据挑战任务中的说明逐步实现即可。

过程指南

1.取得speechSynthesis对象,并取得浏览器支持的朗读语言,将所有支持的选项动态添加至下拉列表

  1. const synth = window.speechSynthesis;
  2. //将获取支持语言并添加至下拉列表的代码段封装在一个函数中
  3. function getSupportVoice() {
  4. voices = synth.getVoices();//获取支持的语言
  5. for(i = 0; i < voices.length ; i++) {
  6. var option = document.createElement('option');
  7. option.textContent = voices[i].name + ' (' + voices[i].lang + ')';
  8. if(voices[i].default) {
  9. option.textContent += ' -- DEFAULT';
  10. }
  11. option.setAttribute('data-lang', voices[i].lang);
  12. option.setAttribute('data-name', voices[i].name);
  13. voicesDropdown.appendChild(option);
  14. }
  15. }
  16. //经测试直接执行getSupportVoice()时无法获得预期效果,须由事件触发该函数。
  17. synth.addEventListener('voiceschanged', getSupportVoice);

2.点击speak按钮后朗读(为方便说明,以下代码段与所提供的完成代码顺序不完全一致)

  1. //实例化配置对象
  2. const msg = new SpeechSynthesisUtterance();
  3. //定义一段默认朗读内容
  4. msg.text = '你能说中文吗';
  5. //点击speak按钮时阅读文字
  6. function speak() {
  7. console.log(voicesDropdown.value);
  8. synth.speak(msg);
  9. }
  10. //将阅读函数绑定至`speak`按钮的点击事件上
  11. speakButton.addEventListener('click', speak);

3.点击stop按钮停止朗读

  1. //停止朗读
  2. function stopSpeak(){
  3. synth.cancel();
  4. }
  5. //将停止朗读函数绑定至`stop`按钮的点击事件上
  6. stopButton.addEventListener('click', stopSpeak);

4.参数配置可更改

  1. //index-start.html中提供的选择器将返回rate值,pitch值以及阅读内容对应的DOM元素
  2. const options = document.querySelectorAll('[type="range"], [name="text"]');
  3. //将阅读参数赋值至msg的同名实例属性
  4. function paramChange(){
  5. msg[this.name] = this.value;
  6. }
  7. options.forEach(opt => opt.addEventListener('change', paramChange));