如何从播放列表中不断播放所有音乐?

时间:2015-06-11 13:20:14

标签: javascript jquery html5

我正在尝试播放播放列表中的音乐。需要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首歌曲,播放器跳过最后一首歌曲并重复播放列表而不播放最后一首歌曲。

1 个答案:

答案 0 :(得分:1)

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

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]);
});