HTML音频播放器轨道链接在新浏览器打开

HTML audio player track links opening in new browser

本文关键字:浏览器 链接 音频 播放器 轨道 HTML      更新时间:2023-09-26

我试图创建一个HTML音频播放器,并有一切功能到目前为止。唯一的问题是,当点击播放列表中的曲目时,mp3将在新的浏览器窗口中加载。

当他们播放按钮被点击时(对于当前选择的轨道),它在音频播放器中播放,这就是我想在点击播放列表时发生的所有轨道。

有什么办法解决这个问题吗?

https://jsfiddle.net/47qh28c6/

HTML

<audio id="audio" preload="auto" tabindex="0" controls="" type="audio/mpeg">
    <source type="audio/mp3" src="http://www.archive.org/download/bolero_69/Bolero.mp3">
    Sorry, your browser does not support HTML5 audio.
</audio>
<ul id="playlist">
    <img style="float:right;width:150px;" src="images/placer.gif">
    <li class="active"><a href="http://www.archive.org/download/bolero_69/Bolero.mp3">Ravel Bolero</a></li>
    <li><a href="http://www.archive.org/download/MoonlightSonata_755/Beethoven-MoonlightSonata.mp3">Moonlight Sonata - Beethoven</a></li>
    <li><a href="http://www.archive.org/download/CanonInD_261/CanoninD.mp3">Canon in D Pachabel</a></li>
    <li><a href="http://www.archive.org/download/PatrikbkarlChamberSymph/PatrikbkarlChamberSymph_vbr_mp3.zip">patrikbkarl chamber symph</a></li>
</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;
audio[0].volume = .10;
audio[0].play();
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('href');
    par = link.parent();
    par.addClass('active').siblings().removeClass('active');
    audio[0].load();
    audio[0].play();
}

您的代码似乎是正确的。我发现您在问题中分享的JSFiddle的唯一问题,以及在JSFiddle中引起所有麻烦的问题,是您没有包括jQuery库。

由于没有添加库,当init()函数到达代码audio = $('audio'):

时将抛出错误。

Uncaught ReferenceError: $ is not defined

,它将停止执行函数中其余的代码,因此影响播放列表内a s行为的代码将不会被执行,并且正常行为(打开链接)不会被修改。

一旦你添加jQuery库到JSFiddle,播放器似乎工作得很好:https://jsfiddle.net/47qh28c6/3/.