由于我将有多个地方,我希望能够使用独特的数据。
而不是像<a class="snippet_show_answers" href="#">Se svar</a>
那样可能像<a DATA="1" class="snippet_show_answers" href="#">Se svar</a>
这样的东西,它应该作为我的脚本的一部分运行,这样它只处理点击的数据,而不是所有的框。
我的HTML就是这个(有多个):
<p class="snippet_answers">Svar: 3 - <span class="green"><a class="snippet_show_answers" href="#">Se svar<img src="images/answerarrow.png" alt="answerarrow" height="14" width="13"></a><a class="snippet_hide_answers" href="#" style="display: none;">Skjul svar<img src="images/answerarrow.png" alt="answerarrow" height="14" width="13"></a></span><hr />
<div class="answers" style="display: none;">
<p>blablabla</p>
</div>
</p>
我的JS是这样的:
$('.snippet_show_answers').live("click", function() {
$('.answers').slideDown("slow");
$('.snippet_show_answers').fadeOut("slow");
$('.snippet_hide_answers').fadeIn("slow");
return false;
});
$('.snippet_hide_answers').live("click", function() {
$('.answers').slideUp("slow");
$('.snippet_hide_answers').fadeOut("slow");
$('.snippet_show_answers').fadeIn("slow");
return false;
});
希望有人理解我,因为我以前见过这种方法,但我不知道它的名字,或者其他什么。
先谢谢。
答案 0 :(得分:2)
获取对被点击项目的父元素的引用,然后使用相应的类查找其后代:
$('.snippet_show_answers').live("click", function() {
var item = $(this).closest(".snippet_answers");
item.find('.answers').slideDown("slow");
item.find('.snippet_show_answers').fadeOut("slow");
item.find('.snippet_hide_answers').fadeIn("slow");
return false;
});
$('.snippet_hide_answers').live("click", function() {
var item = $(this).closest(".snippet_answers");
item.find('.answers').slideUp("slow");
item.find('.snippet_hide_answers').fadeOut("slow");
item.find('.snippet_show_answers').fadeIn("slow");
return false;
});
此外,如果您使用的是最新版本的jQuery,请务必将.live()
更改为.on()
。 .live()
最近被弃用了。