自动播放页面中所有audio标签

摘要:在浏览游戏百科中的BGM部分,想把页面中的音频像音乐播放器一样自动地一首接一首播放,参考了这篇博客以后,写了以下代码,在开发者工具的控制台里运行就行。应该说适用范围比上述参考博客要广,不受DOM树结构影响

在浏览游戏百科中的BGM部分,想把页面中的音频像音乐播放器一样自动地一首接一首播放,参考了这篇博客以后,写了以下代码,在开发者工具的控制台里运行就行。应该说适用范围比上述参考博客要广,不受DOM树结构影响。

var audios = document.getElementsByTagName("audio");
for(var i=0;i<audios.length;i++){
    var current = audios[i];
    current.addEventListener('ended', function () {
        console.log(`${this.src} ended`);
        var audioArr = document.getElementsByTagName("audio");
        for(var j=0;j<audioArr.length;j++){
            if ( this == audioArr[j] ) {
                var nextAudio = audioArr[j+1]
                nextAudio.play();
                console.log(`${nextAudio.src} started.`)
                break;
            }
        }
    }, false);
}
audios[0].play();


如果希望在播放下一首之前能够先缓冲一下,可以添加一些代码

var audios = document.getElementsByTagName("audio");
for(var i=0;i<audios.length;i++){
    var current = audios[i];
    // current.preload = "auto"; // 缓冲所有
    current.addEventListener('ended', function () {
        console.log(`${this.src} ended`);
        var audioArr = document.getElementsByTagName("audio");
        for(var j=0;j<audioArr.length;j++){
            if ( this == audioArr[j] ) {
                var nextAudio = audioArr[j+1];
                nextAudio.play();
                audioArr[j+2].preload = "auto"; // 缓冲下一首
                console.log(`${nextAudio.src} started.`);
                break;
            }
        }
    }, false);
}
audios[0].play();
audios[1].preload = "auto"; // 缓冲下一首

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_6865