ios下音乐不会自动播放,需要手动触发才会播放。但是在微信环境下可以做到自动播放。所以我们可以用下面的代码来实现兼容性自动播放。
//背景音乐开始
//添加一个音乐标签
let el_audio = new Audio();
window.el_audio = el_audio;
//把音乐源文件加入到标签上
el_audio.setAttribute("src", require("./audio/BG.mp3"));
//开启循环播放
el_audio.loop = true;
//设置一个音乐图标
let el_play = document.createElement("img");
el_play.classList.add("music");
el_play.setAttribute("src", require("./images/music.png"));
//监听触摸事件并播放音乐
el_play.addEventListener("touchstart", play);
document.body.appendChild(el_play);
function play(e) {
//去掉冒泡
if (!!e) {
e.stopPropagation && e.stopPropagation();
e.preventDefault && e.preventDefault();
}
//如果开始播放,先停止document监听触摸事件,避免重复触发
document.removeEventListener('touchstart', play);
//如果音乐在播放,则暂停(音乐图标样式也去掉play),否则就播放。图标样式加上play
if (!el_audio.paused) {
el_audio.pause();
el_play.classList.remove("play");
} else {
el_audio.play();
el_play.classList.add("play");
}
}
try {
//微信环境下就自动播放
document.addEventListener("WeixinJSBridgeReady", () => {
WeixinJSBridge.invoke('getNetworkType', {}, play);
});
} catch (e) {
console.warn('非微信环境')
}
var isAppInside = /micromessenger/i.test(navigator.userAgent.toLowerCase()) || /yixin/i.test(navigator.userAgent.toLowerCase());
if (!isAppInside) {//给非微信易信浏览器
play();
if (el_audio.paused) {
document.addEventListener('touchstart', play);
}
}
//背景音乐结束
复制代码