h5背景音乐播放代码

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);
    }
}
//背景音乐结束
复制代码

转载于:https://juejin.im/post/5acabd4551882555784e3f91

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值