不同浏览器音频播放——Uncaught (in promise) DOMException: The play() request was interrupted by a call to pause
之前遇到过一次关于音频播放的功能要求,文章链接如下:音频播报功能链接地址当时在本地谷歌浏览器下运行是没有问题。后面音频播报功能上线后,发现用户使用的是360急速模式,导致音频播报过程中报错,报错信息如下:Uncaught (in promise) DOMException: The play() request was interrupted by a call to pause().本文章是在上
·
之前遇到过一次关于音频播放的功能要求,文章链接如下:
音频播报功能链接地址
当时在本地谷歌浏览器下运行是没有问题。后面音频播报功能上线后,发现用户使用的是360急速模式,导致音频播报过程中报错,报错信息如下:
Uncaught (in promise) DOMException: The play() request was interrupted by a call to pause().
本文章是在上面链接的基础上进行的改进
百度一下后,发现报这个错的原因是因为浏览器禁止音频直接播放导致的。
现在记录一下解决办法:
在需要播放音频的地方
- 先获取音频文件所在的
audio标签——var audio = document.querySelector("audio"); - 让音频加载——
audio.load(); - 音频播放从头开始——
audio.currentTime = 0; - 音频取消静音——
audio.muted = false; - 判断是否支持音频播放——
let playPromise = audio.play();
重点就是这个判断:
let playPromise = audio.play();
if (playPromise) {
console.log("playPromise", playPromise);
playPromise.then(() => {
console.log("开始音频播放");
audio.play();
}).catch(() => {
console.log("音频播放失败");
})
}
整体js如下所示:
var audio = document.querySelector("audio");
audio.load();
audio.currentTime = 0;
audio.muted = false;
let playPromise = audio.play();
if (playPromise) {
console.log("playPromise", playPromise);
playPromise.then(() => {
console.log("开始音频播放");
audio.play();
}).catch(() => {
console.log("音频播放失败");
})
}
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)