如何在html 5中一一播放多个音频文件?

时间:2021-05-18 10:18:38

标签: html5-audio

我想一一播放多个音频文件。我已经阅读了相同的问题,但我发现原始答案的链接不起作用并且问题未得到解答。

Original answer

<audio id="mySound" controls><source src="http://www.hvalur.org/audio/uploaded_files/ds_umkomuleysi_0_0.mp3" type="audio/mpeg"></audio>

<audio id="mySound1" ><source src="http://www.hvalur.org/audio/uploaded_files/ds_ljosmyndavel_0_0.mp3" type="audio/mpeg"></audio>

我希望用户操作(按下播放按钮)启动第一个声音,然后一个个播放以下声音。 这个例子的用途是练习理解母语者阅读的电话号码。

1 个答案:

答案 0 :(得分:1)

我会这样做:

var mySound = document.getElementById("mySound");
var mySound1 = document.getElementById("mySound1");
var mySound2 = document.getElementById("mySound2");
var mySound3 = document.getElementById("mySound3");

var mySoundArray = [mySound, mySound1, mySound2, mySound3];
var mySoundArrayPos = 0;

var myButton = document.getElementById("myButton");
myButton.addEventListener("click", function(event) {
    mySound.play();
    mySoundArrayPos = 0;
    startSoundTimer();
});

const startSoundTimer = () => {
    var mySoundTimer = setInterval(() => {
        if (mySoundArray[mySoundArrayPos].currentTime >= mySoundArray[mySoundArrayPos].duration) {
            if (mySoundArrayPos < mySoundArray.length -1) {
                mySoundArrayPos += 1;
                mySoundArray[mySoundArrayPos].play();
            } else {
                clearInterval(mySoundTimer);
            }
        }
    }, 10);
};

我不知道 10ms 是不是有点太快了,但我认为,这是合法的。

相关问题