gpt4 book ai didi

javascript - 如何连续播放播放列表中的所有音乐?

转载 作者:行者123 更新时间:2023-11-28 00:12:14 24 4
gpt4 key购买 nike

我正在尝试播放播放列表中的音乐。需要javascript函数来连续动态播放所有歌曲。

简单播放器

<audio id="audio" preload="auto" tabindex="0" controls="">
<source type="audio/mp3" src="music/demo.mp3">
Sorry, your browser does not support HTML5 audio.
</audio>

播放列表

<ul id="playlist">
<?php if($lists) { foreach ($lists as $key=> $list) { ?>
<li class="active">
<a src="music/<?php echo $list; ?>.mp3">
<?php echo $list; ?> </a>
</li>
<?php }}?>
</ul>

JavaScript

var audio;
var playlist;
var tracks;
var current;

init();
function init(){
current = 0;
audio = $('audio');
playlist = $('#playlist');
tracks = playlist.find('li a');
len = tracks.length - 1;

playlist.find('a').click(function(e){
e.preventDefault();
link = $(this);
current = link.parent().index();
run(link, audio[0]);
});
audio[0].addEventListener('ended',function(e){
current++;
if(current == len){
current = 0;
link = playlist.find('a')[0];
}else{
link = playlist.find('a')[current];
}
run($(link),audio[0]);
});
}
function run(link, player){
player.src = link.attr('src');
par = link.parent();
par.addClass('active').siblings().removeClass('active');
audio[0].load();
audio[0].play();
}

我的播放列表中有 3 首歌曲,但问题是它只播放前 2 首歌曲,播放器会跳过最后一首歌曲并再次重复播放列表,而不播放最后一首歌曲。

最佳答案

您正在增加当前索引,然后再检查它是否是实际正在播放的最后一个。这样做:

audio[0].addEventListener('ended',function(e){

if(current == len){
current = 0;
link = playlist.find('a')[0];
}else{
link = playlist.find('a')[current];
current++; // <-- Increment after the check
}
run($(link),audio[0]);
});

关于javascript - 如何连续播放播放列表中的所有音乐?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30781991/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com