【vue项目中添加告警音频提示音】

一、前提:

由于浏览器限制不能自动触发音频文件播放,所以实现此类功能时,需要添加触发事件,举例如下:

1、页面添加打开告警声音开关按钮

2、首次进入页面时添加交互弹窗提示:是否允许播放音频

以上两种方法原理都是一样的,即添加交互事件,触发音频播放功能


二、具体代码如下:

dart 复制代码
<template>
	<div>
		<el-button @click="handelPlay" type="primary">开启声音</el-button>
		// 默认声音只播放一次 如需设置循环播放 设置loop
		<audio id="audio" controls="controls" ref="audioRef" :src="音频文件地址" hidden @play="onPlay">Your browser does not support the audio element.</audio>
	</div>
</template>
<script>
export default {
		data() {
			return {
				enableAlarm:false
			}
		},
			
	methods: {
			getData(){
				// 处理告警数据的逻辑
				if(this.enableAlarm&&有告警数据了){
					this.$refs.audio.volume = 1; //  告警声音打开
				}
			},
			// 播放组件
			handlePlay() {
				this.enableAlarm = !this.enableAlarm;
				if (this.enableAlarm) {
					this.play();		 sessionStorage.setItem('enableAlarm',this.enableAlarm)
					this.$refs.audio.volume = 0; // 打开播放事件静音
			},
			onPlay(val) {
				console.log('开始播放声音');
				console.log(val);
			},
			//播放
			play() {
				this.$refs.audio.play();
			},
			//音频暂停
			stop() {
				this.$refs.audio.pause();
				this.$refs.audio.currentTime = 0;
			}
	}
}

</script>

三、参考文章链接:

参考1:
https://blog.csdn.net/Jiaberrr/article/details/142303431

参考2:
https://www.cnblogs.com/Ao-min/p/18428423


四、寄语:

人生岂能都如意,万事只求半称心。

有舍有得有欢喜,且行且远且珍惜。

童年的雨天最是泥泞,却是记忆里最干净的曾经。

相关推荐
JS_GGbond12 小时前
让代码学会“等外卖”:JavaScript异步编程趣谈
前端·javascript
一点晖光12 小时前
小程序中web-view加载uni-app H5如何使用postMessage方法的解决方案
前端·小程序·uni-app
随风一样自由12 小时前
React编码时,什么时候用js文件,什么时候用jsx文件?
开发语言·javascript·react.js
AI分享猿12 小时前
雷池 WAF vs React 高危漏洞:1 毫秒检测延迟,护住全栈业务安全
前端·安全·react.js
开发者小天12 小时前
react中todolist小案例
前端·react.js·前端框架
MQliferecord12 小时前
如何实现倒计时工具
前端
by__csdn12 小时前
Vue3 生命周期全面解析:从创建到销毁的完整指南
开发语言·前端·javascript·vue.js·typescript·前端框架·ecmascript
小年糕是糕手12 小时前
【C++同步练习】模板初阶
服务器·开发语言·前端·javascript·数据库·c++·改行学it
纸人特工12 小时前
NuxtHub部署nuxt项目就是方便
前端
_默_12 小时前
前端常用依赖归纳【vueuse\lodash-es\dayjs\bignumber】
大数据·前端·elasticsearch