在页面刷新时从jquery html5音频播放列表中随机选择曲目

时间:2013-10-23 16:55:01

标签: html5 audio random playlist

我正在为网络体验构建一个音频播放器,它有一个音轨列表。这是控制音频播放器的代码。

$( document ).ready(function() {
jQuery(function($) {
            var supportsAudio = !!document.createElement('audio').canPlayType;
            if(supportsAudio) {
                var index = 0,
                playing = false;
                mediaPath = 'audio/',
                extension = '',
                tracks = [
                    {"track":1,"name":"track1","length":"00:55","file":"track1"},
                    {"track":2,"name":"track2","length":"00:55","file":"track2"},
                    {"track":3,"name":"track3","length":"00:55","file":"track3"},
                    {"track":4,"name":"track4","length":"00:55","file":"track4"},
                    {"track":5,"name":"track5","length":"00:55","file":"track5"}
                ],
                trackCount = tracks.length,
                npAction = $('#npAction'),
                npTitle = $('#npTitle'),
                audio = $('#audio1').bind('play', function() {
                    playing = true;
                    npAction.text('Now Playing:');
                }).bind('pause', function() {
                    playing = false;
                    npAction.text('Paused:');
                }).bind('ended', function() {
                    npAction.text('Paused:');
                    if((index + 1) < trackCount) {
                        index++;
                        loadTrack(index);
                        audio.play();
                    } else {
                        audio.pause();
                        index = 0;
                        loadTrack(index);
                    }
                }).get(0),
                li = $('#plUL li').click(function() {
                    var id = parseInt($(this).index());
                    if(id !== index) {
                        playTrack(id);
                    }
                }),
                loadTrack = function(id) {
                    $('.plSel').removeClass('plSel');
                    $('#plUL li:eq(' + id + ')').addClass('plSel');
                    npTitle.text(tracks[id].name);
                    index = id;
                    audio.src = mediaPath + tracks[id].file + extension;
                },
                playTrack = function(id) {
                    loadTrack(id);
                    audio.play();
                };

                extension = audio.canPlayType('audio/mpeg') ? '.mp3' : audio.canPlayType('audio/ogg') ? '.ogg' : '';
                loadTrack(index);
            }


});
});

有没有办法重新排序名为tracks的变量中的列表?在随机拉动中生成1到5的列表?例如,名为track2 track3 track4等的项目。可能会先玩?我正在寻找在页面刷新时随机的。

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

你可以在track变量中添加一个playOrder字段,然后让一个函数在加载时逐个执行,并为其分配一个随机的未使用的playOrder编号。