【发布时间】:2019-07-06 06:25:06
【问题描述】:
我有这个 HTML 代码:
<div id="1">Paragraph 1</div>
<div id="2">Paragraph 2</div>
<div id="3">Paragraph 3</div>
<div id="4">Paragraph 4</div>
<div id="5">Paragraph 5</div>
<span id="play">play</span>
我想要做的是,当我点击“播放”时,播放第 1 段的音频,在播放时,突出显示这个 div,并在后台加载下一段音频,这样音频就不会停止完全加载,这是到下一个的无缝过渡。现在当第一段的音频播放完毕后,取消突出显示该 div,然后播放下一段的音频并突出显示它并重复该过程直到循环完成。
我认为这很容易通过获取音频文件的持续时间并在 for 循环中播放所有音频来实现。但这不起作用:
$('#play').on("click",function(){
var total_paragraphs = 7;
function playAudio() {
for (var i = 1; i <= total_paragraphs; i++) {
var audio = new Audio("paragraphs/"+i+".mp3");
var sec, ms;
audio.addEventListener("loadedmetadata", function(_event) {
seconds = audio.duration.toFixed(2),
milliseconds = audio.duration.toFixed(2)*1000;
});
$("#"+i).css("background-color", "red");
audio.play();
audio.onended = function() {
$("#"+i).css("background-color", "white");
};
}
}
playAudio();
});
当我点击播放时,所有的音频都会同时播放。似乎所有循环都是同时执行的。我想获得音频文件的持续时间来延迟循环,但这也不起作用。
我确信有很多更简单的方法可以做我想做的事。任何帮助,将不胜感激。
【问题讨论】:
-
audio.onended回调中的i将始终为8。同样,loadedmetadata回调中的audio将始终为new Audio("paragraphs/7.mp3") -
@PatrickRoberts 请问有什么解决方案吗?
标签: javascript jquery html