html:
<div id="videos">
<a href="javascript:loadAndPlayVideo('QXoIMTjk9Xg')"><img src="http://i.ytimg.com/vi/QXoIMTjk9Xg/default.jpg" id="thumb_QXoIMTjk9Xg"></a>
<a href="javascript:loadAndPlayVideo('nWubfMkDfVs')"><img src="http://i.ytimg.com/vi/nWubfMkDfVs/default.jpg" id="thumb_nWubfMkDfVs"></a>
<a href="javascript:loadAndPlayVideo('S3WDKXq36WI')"><img src="http://i.ytimg.com/vi/S3WDKXq36WI/default.jpg" id="thumb_S3WDKXq36WI"></a>
<a href="javascript:loadAndPlayVideo('sGrfLQVVI8A')"><img src="http://i.ytimg.com/vi/sGrfLQVVI8A/default.jpg" id="thumb_sGrfLQVVI8A"></a>
</div>
问题: 我们有id' nWubfMkDfVs ',我们需要知道下一个ID才能获得播放列表功能。
注意:没有thumb_,thumb_是因为我在另一个div中使用id nWubfMkDfVs并且想要避免双重身份
问题1 :如何在使用nWubfMkDfVs时使选择器为S3WDKXq36WI提供响应?
问题2 :如何在使用sGrfLQVVI8A时使选择器为QXoIMTjk9Xg作为响应?
我尝试了很多选择器,但都失败了,我对你如何解决这个问题非常好奇!
答案 0 :(得分:1)
因为您引用嵌套在a中的ID,所以您必须这样做:
$("#nWubfMkDfVs").parent().next("a").children('img')
注意,首先它选择父,然后选择下一个锚,然后选择img child。
答案 1 :(得分:1)
试试这个(demo):
HTML
<div id="videos">
<a href="javascript:loadAndPlayVideo('QXoIMTjk9Xg')"><img src="http://i.ytimg.com/vi/QXoIMTjk9Xg/default.jpg" id="thumb_QXoIMTjk9Xg"></a>
<a href="javascript:loadAndPlayVideo('nWubfMkDfVs')"><img src="http://i.ytimg.com/vi/nWubfMkDfVs/default.jpg" id="thumb_nWubfMkDfVs"></a>
<a href="javascript:loadAndPlayVideo('S3WDKXq36WI')"><img src="http://i.ytimg.com/vi/S3WDKXq36WI/default.jpg" id="thumb_S3WDKXq36WI"></a>
<a href="javascript:loadAndPlayVideo('sGrfLQVVI8A')"><img src="http://i.ytimg.com/vi/sGrfLQVVI8A/default.jpg" id="thumb_sGrfLQVVI8A"></a>
</div>
<br>
current ID: <span class="current"></span>
<br>
<button>Next</button>
脚本
$(document).ready(function() {
var currentID = 'QXoIMTjk9Xg';
$('.current').html(currentID);
$('button').click(function() {
currentID = getNextId(currentID);
$('.current').html(currentID);
});
getNextId = function(id) {
// default to first video if next isn't found
var nxt = $('#videos').find('img[id$=' + id + ']').parent().next().find('img').attr('id') || $('#videos img:eq(0)').attr('id');
return nxt.replace(/thumb_/, '');
}
})