H5背景音乐自动播放(兼容微信IOS,进程后台切换自动停止播放,本文例子为Vue写法)

<template>
    <audio src="./static/music.mp3" id="bgMusic" preload="auto" loop></audio>
    <div class="bgMusicBtn" @click="bgMusicPlayOrPause('bgMusic')">
        <img :src="playFlag ? playImg : pauseImg" :class="{rotate: playFlag}">
    </div>
</template>
 
export default {
    data() {
        return {
            playFlag: true,
            playImg: require('../../static/play.png'),
            pauseImg: require('../../static/pause.png'),
            clickMusicBtn: false
        }
    },
    mounted() {
        this.audioAutoPlay('bgMusic');

        document.addEventListener("visibilitychange", (e) => { // 兼容ios微信手Q
            if (this.clickMusicBtn) { // 点击了关闭音乐按钮
                if (this.playFlag) {
                    this.audioAutoPlay('bgMusic');
                    this.playFlag = true;
                } else {
                    this.audioPause('bgMusic');
                    this.playFlag = false;
                }

                text.innerHTML = e.hidden;
                if (e.hidden) {  // 网页被挂起
                    this.audioAutoPlay('bgMusic');
                    this.playFlag = true;
                } else { // 网页被呼起
                    this.audioPause('bgMusic');
                    this.playFlag = false;
                }
            } else { // 未点击关闭音乐按钮
                if (this.playFlag) {
                    this.audioPause('bgMusic');
                    this.playFlag = false;
                } else {
                    this.audioAutoPlay('bgMusic');
                    this.playFlag = true;
                }

                text.innerHTML = e.hidden;
                if (e.hidden) {  // 网页被挂起
                    this.audioPause('bgMusic');
                    this.playFlag = false;
                } else { // 网页被呼起
                    this.audioAutoPlay('bgMusic');
                    this.playFlag = true;
                }
            }
        });
    },
methods: {
    bgMusicPlayOrPause(id) {
        this.clickMusicBtn = !this.clickMusicBtn;
        if (this.playFlag) {
            this.audioPause(id);
            this.playFlag = false;
        } else {
            this.audioAutoPlay(id);
            this.playFlag = true;
        }
    },
    audioPause(id) {
        var audio = document.getElementById(id);
        audio.pause();
        document.addEventListener("WeixinJSBridgeReady", function () {
            audio.pause();
        }, false);
        document.addEventListener('YixinJSBridgeReady', function () {
            audio.pause();
        }, false);
    },
    audioAutoPlay(id) {
        var audio = document.getElementById(id);
        audio.play();
        document.addEventListener("WeixinJSBridgeReady", function () {
            audio.play();
        }, false);
        document.addEventListener('YixinJSBridgeReady', function () {
            audio.play();
        }, false);
    }
 }
}
posted @   SKILL·NULL  阅读(3561)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示