监听其他音频播放时暂停正在播放的音频
要实现当有其他音频播放时暂停当前音频,你可以使用全局事件总线或 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 方法 :暂停当前音频。
- 事件监听 :在组件销毁前移除事件监听,以防止内存泄漏。
相关文章:
监听其他音频播放时暂停正在播放的音频
要实现当有其他音频播放时暂停当前音频,你可以使用全局事件总线或 Vuex 来管理音频播放状态。这里我将展示如何使用一个简单的事件总线来实现这个功能。 首先,你需要创建一个事件总线。你可以在项目的一个公共文件中创建它,例如 eventBus.js…...
小熊猫C++安装EasyX最新教程
1.下载EasyX 官网下载: EasyX 官网https://easyx.cn/ 2.将下载文件改格式解压 注意:下载文件为.exe格式,需将其格式改成.zip格式! 如何改格式? a.若文件名字未显示.exe (1).打开此电脑 (2).点击上端的查看 (…...
安装VM和Centos
安装VM 一、打开虚拟机 二、选择典型 三、选择光盘 四、指定虚拟机位置 五、设置磁盘大小并拆分为多个文件 六、完成 安装Centos 一、上述过程完成后我们直接打开虚拟机 二、语言选择中文 三、默认安装位置并点击完成 四、点击开始安装 五、点击设置密码 设置完密码后点击完成…...
git 命令 设置别名
在Git中,您可以通过以下命令查看所有的alias(别名): git config --get-regexp alias 这个命令会列出所有配置的alias,例如: alias.st.status alias.co.checkout alias.br.branch ... 如果您想查看某个特定a…...
React + TypeScript 全栈开发最佳实践
React TypeScript 全栈开发最佳实践 一、环境搭建与项目初始化 node.js和npm的安装请参考我的文章。 1.1 脚手架选择与工程创建 # 使用Vite 5.x创建ReactTS项目(2025年主流方案) npx create-vitelatest my-app --template react-ts cd my-app npm in…...
springboot志同道合交友网站设计与实现(代码+数据库+LW)
摘 要 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本志同道合交友网站就是在这样的大环境下诞生,其可以帮助使用者在短时间内处理完毕庞大的数据信…...
防火墙双机热备---VRRP,VGMP,HRP(超详细)
双机热备技术-----VRRP,VGMP,HRP三个组成 注:与路由器VRRP有所不同,路由器是通过控制开销值控制数据包流通方向 防火墙双机热备: 1.主备备份模式 双机热备最大的特点就是防火墙提供了一条专门的备份通道(心…...
MQTT实现智能家居------4、在Linux上运行MQTT
进入主目录,创建一个MQTT文件夹 cd ~ mkdir MQTT 用FileZilla连接开发板,将我发布的压缩包解压以后放进MQTT 安装cmake sudo apt-get install cmake g编译 & 运行 echo sudo apt-get update >> build.sh #向build.sh文件写入内容 chmod…...
VMware建立linux虚拟机
本文适用于初学者,帮助初学者学习如何创建虚拟机,了解在创建过程中各个选项的含义。 环境如下: CentOS版本: CentOS 7.9(2009) 软件: VMware Workstation 17 Pro 17.5.0 build-22583795 1.配…...
大模型文集开篇稿
2023年,我国AI大模型行业规模已达到147亿元人民币(前瞻产业研究院 数据)。AI大模型的行业应用及技术进步能有效提升各行业生产要素的产出效率并提高了数据要素在生产要素组合中的地位。供给方面,当前AI大模型企业主要通过深化通用…...
python pickle模块
pickle 是 Python 的一个标准模块,它实现了基本的二进制协议,用于对象的序列化和反序列化。序列化是指将对象转换为字节流的过程,这样对象就可以被保存到文件中或通过网络传输。反序列化是指将字节流转换回对象的过程。 使用 pickle 序列化对…...
第16届蓝桥杯模拟赛3 python组个人题解
第16届蓝桥杯模拟赛3 python组 思路和答案不保证正确 1.填空 如果一个数 p 是个质数,同时又是整数 a 的约数,则 p 称为 a 的一个质因数。 请问, 2024 的最大的质因数是多少? 因为是填空题,所以直接枚举2023~2 &am…...
企业知识管理战略整合新路径
跨部门知识协同机制 现代企业知识管理的核心挑战在于突破组织孤岛效应,跨部门知识协同机制的构建需依托结构化流程与智能化工具的融合。通过建立标准化知识元数据体系,企业可实现文档分类、版本控制及权限管理的统一规范,其中Baklib作为云端…...
GO 快速升级Go版本
由于底层依赖升级了,那我们也要跟着升,go老版本已经不足满足需求了,必须要将版本升级到1.22.0以上 查看当前Go版本 命令查看go版本 go version [rootlocalhost local]# go version go version go1.21.4 linux/amd64 [rootlocalhost local]# …...
RBAC授权
4 RBAC授权 4.1 什么是RBAC 在Kubernetes中,所有资源对象都是通过API进行操作,他们保存在etcd里。而对etcd的操作我们需要通过访问kube-apiserver来实现,上面的Service Account其实就是APIServer的认证过程,而授权的机制是通过RBA…...
搜广推校招面经三十一
vivo策略算法 一、机器学习中 L1 和 L2 正则化的原理 见【搜广推校招面经二十五】 L1 正则化将某些特征权重置0实现模型简化,而 L2 正则化主要通过平滑权重来实现模型简化。 1.1. 正则化的原理 正则化的核心思想是在损失函数中加入一个惩罚项(Regula…...
【JavaWeb13】了解ES6的核心特性,对于提高JavaScript编程效率有哪些潜在影响?
文章目录 🌍一. ES6 新特性❄️1. ES6 基本介绍❄️2. 基本使用2.1 let 声明变量2.2 const 声明常量/只读变量2.3 解构赋值2.4 模板字符串2.5 对象拓展运算符2.6 箭头函数 🌍二. Promise❄️1. 基本使用❄️2. 如何解决回调地狱问题2.1回调地狱问题2.2 使…...
C++知识整理day9——继承(基类与派生类之间的转换、派生类的默认成员函数、多继承问题)
文章目录 1.继承的概念和定义2.基类与派生类之间的转换3.继承中的作用域4.派生类的默认成员函数5.实现一个不能被继承的类6.继承与友元7.继承与静态成员8.多继承和菱形继承问题8.1 继承分类及菱形继承8.2 虚继承 1.继承的概念和定义 概念: 继承(inheritance)机制是⾯…...
pyautogui库的screenshot()函数
# 方法一 screenshot pyautogui.screenshot() screenshot.save("screenshot.png")# 方法二 # 获取屏幕分辨率 screen_width, screen_height pyautogui.size()# 截取桌面屏幕 screenshot pyautogui.screenshot(region(0, 0, screen_width, screen_height)) screens…...
App测试--逍遥模拟器抓包问题
一、环境 逍遥模拟器、burp、adb、openssl(kali)。 二、配置 1.burp证书转换 下载证书 将burp证书复制进kali,使用kali的openssl(自带),执行以下命令。 openssl x509 -inform der -in cacert.der -out burp.pem openssl x509 -subject_hash_old -in…...
Vue项目中实现Excel样式无损导入:基于ExcelJS与x-spreadsheet的深度解析
1. 为什么需要Excel样式无损导入? 在企业级应用中,Excel文件作为数据交换的"通用语言",经常需要与Web系统进行交互。但传统的数据导入往往只关注内容本身,丢失了字体、颜色、合并单元格等样式信息。这会导致两个核心问题…...
告别HAL迷茫:在STM32F103上体验LL库操控GPIO的极致效率(附代码对比)
突破HAL瓶颈:STM32F103的LL库GPIO开发实战与性能优化 在嵌入式开发领域,效率就是生命线。当你的STM32项目遇到性能瓶颈时,是否曾思考过HAL库可能正在悄悄吞噬宝贵的时钟周期?本文将带你深入LL库的世界,揭示如何通过寄存…...
用Python的statsmodels库做游程检验:从数据清洗到结果解读的完整实战
Python实战:用statsmodels玩转游程检验的7个关键场景 游程检验这个看似冷门的统计方法,在实际业务中能解决哪些棘手问题?当你的A/B测试结果看起来"不太对劲",当用户行为序列出现可疑模式,或者生产线上的质量…...
从零构建:基于Simulink的导弹制导系统全流程建模实战
1. 导弹制导系统建模基础 导弹制导系统建模可不是简单的搭积木,它涉及到复杂的物理原理和工程实现。我刚开始接触这个领域时,也被各种专业术语搞得晕头转向。但经过多次实践后发现,只要掌握几个核心概念,就能快速入门。 首先得明白…...
如何用智能工具10分钟搞定黑苹果配置:OpCore-Simplify终极实战指南
如何用智能工具10分钟搞定黑苹果配置:OpCore-Simplify终极实战指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为复杂的黑苹果配置…...
MCE丨重组蛋白融合标签:从设计到纯化的实战指南
1. 重组蛋白融合标签的设计策略 刚开始接触重组蛋白表达时,我也曾被各种融合标签搞得晕头转向。直到在实验室熬了三个通宵纯化失败后,才真正明白标签设计的重要性。融合标签就像给蛋白质装上的"导航仪",不仅能帮我们快速找到目标蛋…...
异步电机控制进阶:从标量到矢量,解锁高性能工业驱动的核心
1. 异步电机控制技术演进:从基础调速到高精度驱动 第一次接触变频器时,我被操作面板上密密麻麻的参数搞懵了——为什么同样是调节电机转速,有的模式叫V/F控制,有的却标注着SVC、FOC这些英文缩写?后来在调试水泥厂风机系…...
如何彻底解决RimWorld卡顿:Performance Fish性能优化完整指南
如何彻底解决RimWorld卡顿:Performance Fish性能优化完整指南 【免费下载链接】Performance-Fish Performance Mod for RimWorld 项目地址: https://gitcode.com/gh_mirrors/pe/Performance-Fish 如果您正在RimWorld中管理大型殖民地时遭遇令人沮丧的游戏卡顿…...
WebLaTeX:免费在线LaTeX编辑器的终极解决方案,告别复杂安装的学术写作新体验
WebLaTeX:免费在线LaTeX编辑器的终极解决方案,告别复杂安装的学术写作新体验 【免费下载链接】WebLaTex A complete alternative for Overleaf with VSCode Web Git Integration Copilot Grammar & Spell Checker Live Collaboration Support. …...
STK与Python联合仿真实战:构建Walker星座并自动化评估覆盖性能
1. 从零开始:STK与Python联合仿真环境搭建 第一次接触STK和Python联合仿真时,我花了两天时间才把环境配置明白。现在回想起来,其实关键步骤就几个,但当时没人指点确实走了不少弯路。先说说最基础的准备工作,我会尽量把…...
