监听其他音频播放时暂停正在播放的音频

news/2025/2/27 6:03:21/

要实现当有其他音频播放时暂停当前音频,你可以使用全局事件总线或 Vuex 来管理音频播放状态。这里我将展示如何使用一个简单的事件总线来实现这个功能。

首先,你需要创建一个事件总线。你可以在项目的一个公共文件中创建它,例如 eventBus.js :

import Vue from 'vue';
export const EventBus = new Vue();

然后,在你的组件中使用这个事件总线来监听和触发音频播放事件:

<script>
import { EventBus } from '../../../../eventBus' // 引入事件总线export default {name: 'TrialListening',mixins: [rendererMixin],data() {return {playStateIcon: ['play-icon', 'pause-icon', 'loading-icon'],playState: 0,audioInstance: null,    }},methods: {/*** 播放音频* @param {String} url - 音频的URL*/playAudio(url) {this.playState = 2; // 设置为加载中状态const audio = new Audio(url);// 触发全局事件,通知其他音频暂停EventBus.$emit('pauseAllAudio');audio.play().then(() => {this.playState = 1; // 设置为播放状态}).catch(error => {console.error('音频播放失败:', error);this.playState = 0; // 恢复为初始状态});// 监听音频播放结束事件audio.addEventListener('ended', () => {this.playState = 0; // 恢复为初始状态});this.audioInstance = audio;// 监听全局暂停事件EventBus.$on('pauseAllAudio', this.pauseAudio);},/*** 暂停音频*/pauseAudio() {if (this.audioInstance) {this.audioInstance.pause();this.playState = 0; // 设置为暂停状态}}},beforeDestroy() {// 组件销毁前移除事件监听EventBus.$off('pauseAllAudio', this.pauseAudio);}
}
</script>

说明

  • 事件总线 :使用 EventBus 来在组件之间传递事件。
  • playAudio 方法 :在播放音频时触发 pauseAllAudio 事件,通知其他组件暂停音频。
  • pauseAudio 方法 :暂停当前音频。
  • 事件监听 :在组件销毁前移除事件监听,以防止内存泄漏。

http://www.ppmy.cn/news/1575187.html

相关文章

NFT质押:数字资产的价值裂变与收益体系深度解析

NFT质押开启数字资产的复利时当数字艺术品的拍卖价突破百万美元&#xff0c;当元宇宙土地交易量单日暴涨300%&#xff0c;NFT早已超越加密圈的热门概念&#xff0c;演变为承载真实价值的数字资产。在这场变革中&#xff0c;一个更深刻的趋势正在浮现&#xff1a;NFT正从"静…

Ubuntu22中的bash脚本记录

1 .for;do;done的使用对于批量处理非常方便 任务描述&#xff1a;需要使用多个不同位置的脚本&#xff0c;来处理一个路径下的数据集&#xff0c;在这个数据集中&#xff0c;还有若干不同的场景 脚本思想&#xff1a;为了简单方便&#xff0c;先赋值好各种路径&#xff0c;比…

数据驱动未来!天合光能与永洪科技携手开启数字化新篇章

在信息化时代的今天&#xff0c;企业间的竞争早就超越了传统产品与服务的范畴&#xff0c;新的核心竞争力即——数据处理能力和信息技术的应用。作为数据技术领域的领军者&#xff0c;永洪科技凭借其深厚的技术积累和丰富的行业经验&#xff0c;成功助力天合光能实现数字化升级…

excel单、双字节字符转换函数(中英文输入法符号转换)

在Excel中通常使用函数WIDECHAR和ASC来实现单、双字节字符之间的转换。其中 WIDECHAR函数将所有的字符转换为双字节&#xff0c;ASC函数将所有的字符转换为单字节 首先来解释一下单双字节的含义。单字节一般对应英文输入法的输入&#xff0c;如英文字母&#xff0c;英文输入法…

十、大数据资源平台功能架构

一、大数据资源平台的功能架构图总体结构 大数据资源平台功能架构图 关键组件&#xff1a; 1.用户&#xff08;顶行&#xff09; 此部分标识与平台交互的各种利益相关者。 其中包括&#xff1a; 市领导 各部门分析师 区政府 外部组织 公民 开发人员 运营经理 2.功能模…

STM32的C语言软件延时函数

STM32的延时方法很多&#xff0c;其中采用定时器延时&#xff0c;可以得到较为精确的延时&#xff0c;但是有时对延时精度要求不高的场合&#xff0c;采用软件延时&#xff0c;也是必须的。特别是在RTOS系统中&#xff0c;使用SysTick的普通计数模式对延迟进行管理&#xff0c;…

【江科协-STM32】5. 输出比较

1. 输出比较简介 OC(Output Compare)输出比较。 输出比较可以通过CNT&#xff08;CNT计数器&#xff09;与CCR寄存器值的关系&#xff0c;来对输出电平进行置1、置0或翻转的操作&#xff0c;用于输出一定频率和占空比的PWM波形。 :::tip CNT计数器是正向计数器。它只能正向累…

React加TypeScript最新部署完整版

React TypeScript 全流程部署指南 一、环境准备与项目初始化 关于node.js及npm的安装请参见我的文章。 1.1 创建项目&#xff08;React TypeScript&#xff09; # 使用官方推荐脚手架&#xff08;Vite 5.x&#xff09; npx create-vitelatest my-app --template react-ts …