gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 01:59:52 26 4
gpt4 key购买 nike

我正在尝试创建一个 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 that you shared in the question ,而在 JSFiddle 中引起所有麻烦的是您没有包含 jQuery 库。

由于您没有添加库,init()函数到达代码 audio = $('audio') 时会抛出错误:

Uncaught ReferenceError: $ is not defined



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

将 jQuery 库添加到 JSFiddle 后,播放器似乎工作正常: https://jsfiddle.net/47qh28c6/3/ .

关于javascript - HTML 音频播放器轨道链接在新浏览器中打开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32555943/

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