vue2中,前端实现语音播报

devtools/2024/9/24 21:07:46/

一、播报情况说明

vue中语音播报,目前本人写的过程中,遇到了两种情况,第一种是后端直接返回一个mp3的播放url,第二种就是播报的内容需要前端自己拼接的,关于两种方法,我都说一下如何实现

1、后端直接返回mp3播放的url,

从后端拿到的url,以后,可以直接使用new Audio来创建,以下是我的代码,这样写就可以直接播报了

// 这里的OPERATION_BASE_URL,是我的项目基地址
// alarmAudioUrl是后端返回的语音url地址let AlarmAudioUrl = OPERATION_BASE_URL + "/" + alarmAudioUrl;let mp3 = new Audio(AlarmAudioUrl);mp3.play();let times = undefined;mp3.oncanplay = () => {times = mp3.duration;};

2、前端自己拼接文字信息来播报

语音播报的文字是前端自己拼接的,此时就要用另一种方法,贴上我的代码,我就自己重新开一个项目demo,


<template><div><button @click="playVoice">播放语音</button></div>
</template>
<script>
const synth = window.speechSynthesis;
const msg = new SpeechSynthesisUtterance();
export default {data() {return {message :'小朋友,你是否有很多问号,hhhhhhhhhhhhhhhhhhhhhh'};},methods: {playVoice() {// message 假设message是你拼接好的文本信息this.handleSpeak(this.message ); // 传入需要播放的文字},// 语音播报的函数// 比如你从后端接收完数据,并且自己拼接好以后,就可以直接调这个方法,传入你的文本,就可以播放了handleSpeak(text) {msg.text = text; // 文字内容: 小朋友,你是否有很多问号msg.lang = 'zh-CN'; // 使用的语言:中文msg.volume = 1; // 声音音量:1msg.rate = 1; // 语速:1msg.pitch = 1; // 音高:1synth.speak(msg); // 播放},},
};
</script>

http://www.ppmy.cn/devtools/85229.html

相关文章

搭建基于 ChatGPT 的问答系统第五章-思维链推理

需要学习提示词工程的同学请看面向开发者的提示词工程 前几章内容请查看 搭建基于 ChatGPT 的问答系统第一章-综述 搭建基于 ChatGPT 的问答系统第二章-提问范式与Token 搭建基于 ChatGPT 的问答系统第三章-评估输入分类 搭建基于 ChatGPT 的问答系统第四章-检查输入审核 第五…

笔记分类的烦恼

前言 你是否为笔记的分类而苦恼&#xff0c;是否迷失在市面上纷繁复杂的笔记分类法&#xff1f; 不用再烦恼了&#xff0c;本文将介绍一个适用于个人笔记的终极分类办法&#xff0c;只需三刀&#xff0c;尘埃落定。 &#x1f52a; 第一刀 笔记场景 &#x1f370; 也就是笔记…

力扣高频SQL 50题(基础版)第十题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第十题1661. 每台机器的进程平均运行时间题目说明思路分析实现过程准备数据实现方式结果截图总结 力扣高频SQL 50题&#xff08;基础版&#xff09;第十题 1661. 每台机器的进程平均运行时间 题目说明 表: Activity…

Java面试八股之后Spring、spring mvc和spring boot的区别

Spring、spring mvc和spring boot的区别 Spring, Spring Boot和Spring MVC都是Spring框架家族的一部分&#xff0c;它们各自有其特定的用途和优势。下面是它们之间的主要区别&#xff1a; Spring: Spring 是一个开源的轻量级Java开发框架&#xff0c;最初由Rod Johnson创建&…

系统架构设计师②:操作系统

系统架构设计师②&#xff1a;操作系统 操作系统作用 ①管理系统的硬件、软件、数据资源 ②控制程序运行 ③人机之间的接口 ④应用软件与硬件之间的接口 进程管理 进程是程序在一个数据集合上运行的过程&#xff0c;它是系统进行资源分配和调度的一个独立单位。它由程序块、…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 开源项目热度排行榜(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆Coding ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测,专栏文章质量平均 93 分 最新华为OD机试目录…

Redis在SpringBoot中配置

lettuce redis的使用方法有两种&#xff0c;jedis和lecttuce&#xff0c;jedis用的不是很多&#xff0c;下面讲解用lettuce的使用方法。 首先导包&#xff1a; <!--redis依赖--> <dependency><groupId>org.springframework.boot</groupId><artif…

Apollo使用(3):分布式docker部署

Apollo 1.7.0版本开始会默认上传Docker镜像到Docker Hub&#xff0c;可以按照如下步骤获取 一、获取镜像 1、Apollo Config Service 获取镜像 docker pull apolloconfig/apollo-configservice:${version} 我事先下载过该镜像&#xff0c;所以跳过该步骤。 2、Apollo Admin S…