SpeechSynthesisUtterance文字语音播报, 循环播报, 方法封装多组件使用, 自定义播报音色音量音调

老规矩, 先赞后看

1, 基础使用

开始播放, 播放完自动结束

js 复制代码
window.speechSynthesis.speak(new SpeechSynthesisUtterance('哈哈哈'))

手动结束

js 复制代码
window.speechSynthesis.cancel()

其他参数

js 复制代码
let ut = new SpeechSynthesisUtterance('哈哈哈')
    ut.xxx
`text`     -- 播放的内容, 例如上面的'哈哈哈'
`lang`     -- 播放的语言,例如:`zh-cn`
`voiceURI` -- 指定希望使用的声音和服务,字符串。
`volume`   -- 音量,区间范围是`0`到`1`,默认是`1`。
`rate`     -- 语速,默认值是`1`,范围是`0.1`到`10`,表示语速的倍数,例如`2`表示正常语速的两倍。
`pitch`    -- 音调,范围从`0`(最小)到`2`(最大)。默认值为`1`。

暴露的方法
`onstart`  -- 语音合成开始时候的回调。
`onpause`  -- 语音合成暂停时候的回调。
`onresume` -- 语音合成重新开始时候的回调。
`onend`    -- 语音合成结束时候的回调。

其他方法

js 复制代码
window.speechSynthesis.xxxx
speak()   播放
cancel()  结束
pause()   暂停
resume()  恢复暂停的语音

2, 自定义播放次数

js 复制代码
function playVoice(text, times = 1) {
      let count = 0
      const play = () => {
        if (count < times) {
          let utterance = new SpeechSynthesisUtterance(text)
          utterance.onend = () => {
            count++
            if (count < times) {
              setTimeout(() => {
                play()
              }, 1000)
            }
          }
          window.speechSynthesis.speak(utterance)
        }
      }
      play()
    }
playVoice('好好好', 3)

3, 多次播放 方法封装使用

新建speech.js

js 复制代码
// 定义一个class
class SpeechManager {
  constructor() {
    this.utterance = null
    this.isPlaying = false
    this.repeatTimeout = null
  }

  // 播放语音
  speak(text, options = {}) {
    const {
      repeat = false, // 是否重复播放
      repeatDelay = 500 // 重复播放延迟时间(ms)
    } = options

    // 取消之前的语音
    this.cancel()

    this.utterance = new SpeechSynthesisUtterance(text)

    if (repeat) {
      this.utterance.onend = () => {
        this.repeatTimeout = setTimeout(() => {
          if (this.isPlaying) {
            window.speechSynthesis.speak(this.utterance)
          }
        }, repeatDelay)
      }
    }

    this.isPlaying = true
    window.speechSynthesis.speak(this.utterance)
  }

  // 取消语音播放
  cancel() {
    this.isPlaying = false
    if (this.repeatTimeout) {
      clearTimeout(this.repeatTimeout)
      this.repeatTimeout = null
    }
    window.speechSynthesis.cancel()
  }
}

// 导出
export default new SpeechManager()

在需要使用的页面里导入

js 复制代码
import speechManager from '@/util/speech.js'

//某个方法里面需要使用
xxx(){
  // 两个字段, 播放的文本和是否重复播放
  speechManager.speak('请将身份证放置刷卡区或手动输入证件号', { repeat: true })
}


//某个方法里面结束播放
xxx(){
  speechManager.cancel()
}

4, 封装的源码js已经上传, 需要自取 点击前往

没了, 记录一下, 下期再见! END-------------------

相关推荐
不一样的少年_1 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr3 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
BingoGo4 分钟前
免费可商用商业级管理后台 CatchAdmin V5 正式发布 插件化与开发效率的全面提升
vue.js·后端·php
行者9612 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang13 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习
IT_陈寒15 分钟前
SpringBoot 3.0实战:这5个新特性让你的开发效率提升50%
前端·人工智能·后端
哈__20 分钟前
React Native 鸿蒙跨平台开发:LayoutAnimation 实现鸿蒙端页面切换的淡入淡出过渡动画
javascript·react native·react.js
遗憾随她而去.24 分钟前
Webpack 面试题
前端·webpack·node.js
我要敲一万行25 分钟前
前端文件上传
前端·javascript
恋猫de小郭27 分钟前
Tailwind 因为 AI 的裁员“闹剧”结束,而 AI 对开源项目的影响才刚刚开始
前端·flutter·ai编程