如何将 .live 添加到此代码中?
我的网站是一个音乐网站,每个页面上有 24 个单曲播放器。问题是播放器没有加载到新加载的页面上。
我在我的网站上使用无限滚动,但无法获得回调来处理我的无限滚动代码,因此根据我的研究,.live 是下一步要采取的步骤。
不幸的是,我不知道如何在我的代码中实现 .live 。我不确定它是否适用于这种情况。
有没有人有任何相关的例子,甚至可以帮助解决这种情况。
音频播放器代码如下:
//Audio jquery
$(function(){
$(".audio").mb_miniPlayer({
width:210,
height:34,
inLine:false,
onEnd:playNext
});
var $audios = $('.audio');
function playNext(idx) {
var actualPlayer=$audios.eq(idx),
$filteredAtoms = $container.data('isotope').$filteredAtoms,
isotopeItemParent = actualPlayer.parents('.isotope-item'),
isoIndex = $filteredAtoms.index( isotopeItemParent[0] ),
nextIndex = ( isoIndex + 1 ) % $filteredAtoms.length;
$filteredAtoms.eq( nextIndex ).find('.audio').mb_miniPlayer_play();
};
});
不确定是否需要,但这里是无限滚动代码:
//Inifinite Scroll
var $container = $('#container');
$container.isotope({
itemSelector : '.square'
});
$container.infinitescroll({
navSelector : '#page_nav', // selector for the paged navigation
nextSelector : '#page_nav a', // selector for the NEXT link (to page 2)
itemSelector : '.square', // selector for all items you'll retrieve
loading: {
finishedMsg: 'No more pages to load.',
img: 'http://i.imgur.com/qkKy8.gif'
}
},
// call Isotope as a callback
function( newElements ) {
var $newElements = $(newElements);
// add hover events for new items
bindSquareEvents( $newElements );
setTimeout(function() {
$container.isotope('insert', $newElements );
}, 1000);
});
Div 示例:
<div class="square pop">
<!-- DJ Picture -->
<img src="Pictures/adrianlux.jpg" class="img1" />
<div class="boxtop">
<span class="genre">Pop</span>
</div>
<div class="box">
<a class="close" href="#close">×</a>
<!-- DJ Name -->
<h1>Adrian Lux</h1>
<!-- Song Title -->
<h2>Alive (Extended Mix)</h2>
<!--Song Description(179 characters with spaces)-->
<h4>Although this is not truly a pop song, I don't think it can be classified as anything else. The transition from spoken-word lyrics to rising vocals is wonderful as is the drop that follows.</h4>
<div class="buttons">
<!--Song file info-->
<div class="player">
<a id="m75" class="audio {skin:'#010101',showVolumeLevel:false,showTime:false,showRew:false,ogg:'MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).ogg'}" href="MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).mp3"></a></div>
<!--Download Link-->
<div class="download">
<a href="MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).mp3" title='Right Click and Save Link As'>
<img src="img/dlicon.png"/></a>
</div>
</div>
</div>
</div>
My site is a music site that with 24 single song players on each page. The problem is that the player isn't loading on the newly loaded pages.
I am using infinite scroll on my website and I cant get a callback to work on my infinite scroll code, so from what I have researched, .live is the next step to take.
Unfortunately, I dont know how to implement .live into my code. I am not sure if it's even applicable for this situation.
Does anyone have any relevant examples or even help with the situation.
The audio player code is as follows:
//Audio jquery
$(function(){
$(".audio").mb_miniPlayer({
width:210,
height:34,
inLine:false,
onEnd:playNext
});
var $audios = $('.audio');
function playNext(idx) {
var actualPlayer=$audios.eq(idx),
$filteredAtoms = $container.data('isotope').$filteredAtoms,
isotopeItemParent = actualPlayer.parents('.isotope-item'),
isoIndex = $filteredAtoms.index( isotopeItemParent[0] ),
nextIndex = ( isoIndex + 1 ) % $filteredAtoms.length;
$filteredAtoms.eq( nextIndex ).find('.audio').mb_miniPlayer_play();
};
});
Not sure if this is needed, but here is the infinite scroll code:
//Inifinite Scroll
var $container = $('#container');
$container.isotope({
itemSelector : '.square'
});
$container.infinitescroll({
navSelector : '#page_nav', // selector for the paged navigation
nextSelector : '#page_nav a', // selector for the NEXT link (to page 2)
itemSelector : '.square', // selector for all items you'll retrieve
loading: {
finishedMsg: 'No more pages to load.',
img: 'http://i.imgur.com/qkKy8.gif'
}
},
// call Isotope as a callback
function( newElements ) {
var $newElements = $(newElements);
// add hover events for new items
bindSquareEvents( $newElements );
setTimeout(function() {
$container.isotope('insert', $newElements );
}, 1000);
});
Div example:
<div class="square pop">
<!-- DJ Picture -->
<img src="Pictures/adrianlux.jpg" class="img1" />
<div class="boxtop">
<span class="genre">Pop</span>
</div>
<div class="box">
<a class="close" href="#close">×</a>
<!-- DJ Name -->
<h1>Adrian Lux</h1>
<!-- Song Title -->
<h2>Alive (Extended Mix)</h2>
<!--Song Description(179 characters with spaces)-->
<h4>Although this is not truly a pop song, I don't think it can be classified as anything else. The transition from spoken-word lyrics to rising vocals is wonderful as is the drop that follows.</h4>
<div class="buttons">
<!--Song file info-->
<div class="player">
<a id="m75" class="audio {skin:'#010101',showVolumeLevel:false,showTime:false,showRew:false,ogg:'MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).ogg'}" href="MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).mp3"></a></div>
<!--Download Link-->
<div class="download">
<a href="MP3/Adrian Lux feat. The Good Natured - Alive (Extended Mix).mp3" title='Right Click and Save Link As'>
<img src="img/dlicon.png"/></a>
</div>
</div>
</div>
</div>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
任何事件委托 .on() .live() .delegate() 唯一有帮助的方法是,如果您计划完全放弃 mb_miniPlayer 并编写自己的 javascript。当然,您可以将“歌曲播放器”的所有功能(例如:开始、停止、暂停)从特定元素中移开,并将它们移至页面上持久存在的位置。
所有事件委托所做的就是移动控制。例如,绑定普通旧点击处理程序的替代方法如下:
但可以通过以下方式完成相同的功能:
jsFiddle
我们所做的是将事件处理程序从
本身移动到
。 .on() 的第二个参数是用于过滤的可选选择器。在本例中,在
上发生的所有点击中,我们只对源自
的点击感兴趣。
不幸的是,这对您的问题帮助不大。 .live() 并不是某些人认为的万能药。它并没有神奇地使页面“更加生动”。它所做的是将事件处理从可能是暂时的(比如我们可以动态生成的链接)转移到更永久的东西(身体是一个非常安全的目标)。
这里的问题是你的无限滚动条,如果当你运行 javascript(实例化播放器的部分)时页面上不存在某些东西,那么它们就不能很好地被“激活”。并且使用 .live() .delegate() 或 .on() 都无法将它们带回来。
你能做的就是找到一种方法来连接有问题的 JavaScript 并使其执行你需要的操作,即实例化新加载的播放器。 您使用的是什么插件?我也许可以提供一种方法来连接它。
编辑: 如果无法测试您的页面,这将有点棘手,但看起来您的无限滚动插件提供了每次加载新内容并且您已经在使用它时都会触发的回调。这是完美的,我们在那里添加:
这里的想法是搜索新内容以找到新的音频播放器并激活它们。由于 playNext() 是在同一函数中定义的,因此使用它作为“onEnd”应该可以正常工作。
The only way any event delegation .on() .live() .delegate() would help is if you planned on abbandonning mb_miniPlayer completely and writing your own javascript. Then sure, you could take all of the functionality of the "song players" (eg:start,stop,pause) away from the particular elements and move them up to something persistent on the page.
What all event delegation does is move control. For example, an alternative to binding a plain old click handler could be as follows:
But the same functionality could be accomplished with:
jsFiddle
What we have done is move the event handler from the
<a>
itself, up to the<body>
. The second argument of .on() is an optional selector to filter with. In this case, of all the clicks which happen on the<body>
we are only interested in those that originated from<a class="otherLink">
.Unfortunately this is of little help for your problem. .live() is not the cure-all that some seem to think. It doesn't magically make the page "more live". What it does do is move the event handling from something that might be transient (like a link we could generate dynamically) to something more permanent (the body is a pretty safe target).
The problem here is you infinite scroller, if something doesn't exist on the page when you run your javascript (the part that is instantiating the players) then they can't very well be "activated". And no use of .live() .delegate() OR .on() can bring them back.
What you can do, is find a way to hook into the offending javascript and make it do what you need it to, which is to instantiate your newly loaded players. What is the plugin you are using? I may be able to offer a way to hook into it.
EDIT: This will be a little tricky without being able to test your page, but it looks like your infinite-scroll plugin provides a callback which fires every time it loads new content and you are using it already. That is perfect, and we add on there:
The idea here is to search the new content for new audio players and activate them. Since playNext() was defined within the same function, using that as your 'onEnd' should work fine.