vue背景音频播放以及failed because the user didn‘t interact with the document first问题

先说一下报错的原因
在用户没有任何操作的情况下直接播放背景音乐是不行的,有的浏览器支持有的不支持。错误的意思是,在尝试访问用户的文件系统或数据库之前,用户未与文档进行任何交互。

背景音频的使用

第一种

javascript 复制代码
<audio id="background-music" style="visibility: visible;" src="xxxxxx.mp3"></audio>

mounted() {
  //当鼠标点击后就有了交互事件,再获取音频播放
   document.addEventListener('click', (event) =>{
    	console.log('开始音频')
   		const audio = document.getElementById('background-music');
  		audio.play();
   })
    //   document.addEventListener('keydown', function(event) {
    //     console.log('按下键盘键码:');
    //   });
},

第二种

javascript 复制代码
mounted() {
  //当鼠标点击后就有了交互事件,再获取音频播放
   document.addEventListener('click', (event) =>{
	 let audio = new Audio();
	 audio.controls = false; //这样控件才能显示出来
	 audio.src = 'xxxxx.mp3'; //音乐的路径
	 document.body.appendChild(audio);
	 audio.play();
 })
}
相关推荐
兆子龙1 天前
ahooks useRequest 深度解析:一个 Hook 搞定所有请求
java·javascript
兆子龙1 天前
React Suspense 从入门到实战:让异步加载更优雅
java·javascript
KKKK1 天前
SSE(Server-Sent Events)流式传输原理和XStream实践
前端·javascript
子兮曰1 天前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端
Din1 天前
主动取消的防抖
前端·javascript·typescript
H5开发新纪元1 天前
Nginx 部署 Vue3 项目完整指南
前端·javascript·面试
决斗小饼干1 天前
跨语言移植手记:把 TypeScript 的 Codex SDK 请进 .NET 世界
前端·javascript·typescript
进击的尘埃1 天前
Vitest 浏览器模式:别再用 jsdom 骗自己了
javascript
bluceli1 天前
JavaScript模块化深度解析:从CommonJS到ES Modules的演进之路
前端·javascript