我在网站上使用花哨的音乐播放器,我有以下格式的多个播放列表:
<div class="playlist">
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
</div>
<div class="playlist">
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
</div>
<div class="playlist">
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
<a href="mysong.mp3" class="fmp-my-track add_link">add this song</a>
</div>
我希望当用户第一次点击一个播放列表中的任何链接时,它会清除播放列表,然后在下一次点击时添加播放列表中的歌曲。例如,当用户点击第一个播放列表中的任何链接时,它会清除播放列表并将歌曲添加到播放列表中,并且在此播放列表中的下一次点击中,它将不会清除播放列表。当用户第一次点击来自其他播放列表的任何链接时,它将清除播放列表,然后它将添加歌曲。我使用下面的代码来实现这一点,但它不起作用:
$(".playlist").each(function(){
$(".add_link").one("click", function(){
$.fancyMusicPlayer.clear();
});
$(".add_link").click(function(){
$.fancyMusicPlayer.addTrack(this.href, this.title, this.target,false);
});
});
在播放列表中添加歌曲工作正常,但首次点击时清除播放列表的功能无效。任何人都可以帮助我吗?
答案 0 :(得分:1)
您有选择器问题。您希望迭代每个播放列表,并为每个播放列表中的每个add_link分配行为。但是你正在做的是将行为分配给每个add_link ON PAGE,而不是每个播放列表。 $('。add_link')每次迭代都会抓取页面上的每个项目。
你应该这样做:
$('.playlist').each(function() {
$(this).find('.add_link').one(...);
$(this).find('.add_link').click(...);
});
答案 1 :(得分:1)
您需要保留当前播放列表的引用,以检查新的点击是来自同一个播放列表还是其他播放列表。由于您当前的播放列表元素没有id,我在下面的示例代码中使用了它们的索引:
var inPlaylist = 0;
$(".add_link").click(function(){
var playlistIndex = $(this).parent('.playlist').index();
if(playlistIndex != inPlaylist){
$.fancyMusicPlayer.clear();
inPlaylist = playlistIndex;
}
$.fancyMusicPlayer.addTrack(this.href, this.title, this.target,false);
});