使其包含唯一数据

时间:2013-01-05 00:56:01

标签: javascript jquery html

由于我将有多个地方,我希望能够使用独特的数据。

而不是像<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;
});

希望有人理解我,因为我以前见过这种方法,但我不知道它的名字,或者其他什么。

先谢谢。

1 个答案:

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

相关问题