0

因为我将有多个地方,所以我想让它与独特的数据一起工作。

而不是<a class="snippet_show_answers" href="#">Se svar</a>then 之类的东西<a DATA="1" class="snippet_show_answers" href="#">Se svar</a>,然后应该作为我脚本的一部分运行,以便它只处理单击的 DATA,而不是所有框。

我的 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;
});

希望有人能理解我,因为我以前见过这种方法,但我不知道它的名字,或任何东西。

先谢谢了。

4

1 回答 1

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()最近被弃用了。

于 2013-01-05T01:13:06.503 回答