1
$('.option').click(function(){
        $(this).addClass('selected');
        });
    $('.selected').click(function(){
        $(this).removeClass('selected');
        });

当我单击具有类(选定)的元素时,试图删除选定的类。

addClas 有效,但 remove 无效。:/

4

3 回答 3

4

您可以使用toggleClass.

$('body').on('click', '.option', function() {
    $(this).toggleClass('selected');
});
于 2013-07-26T17:46:17.123 回答
3

您的问题是您将事件附加到尚未准备好接收该事件的元素。您应该将事件附加到父元素,然后您可以过滤.selected. 这样,添加可点击元素时无关紧要,它会起作用。这称为事件委托。您将处理事件的任务委托给另一个元素。

你的 JS:

$(document).on("click", ".selected", function() {
    $(this).removeClass('selected');
});

$(document).on("click", ".option", function() {
    $(this).addClass('selected');
});

如果您不需要单个按钮上的不同功能(我假设您会这样做),您可以将两者结合起来:

$(document).on('click','.selected.option',(function() {
    $(this).toggleClass('selected');
});

此外,在执行此操作时,不要将其附加到树上太高的父级。您想将其附加到最近的可能父元素。我们不需要在类似的东西上设置点击事件,document因为最好具体说明哪些元素将获得此事件。将其附加到document将意味着任何具有 类的元素.selected都可以点击并响应相同的代码。如果您想在不同的按钮中具有不同的功能,则不能,因为它们都响应附加到document.

于 2013-07-26T17:49:06.707 回答
1
$('.option').on('click', function(){
    if(!$(this).hasClass("selected")) {
        $(this).addClass('selected');
    }
});
$('.selected').on('click', function(){
    $(this).removeClass('selected');
});

但是使用切换类方法你会得到最好的!

于 2013-07-26T17:50:59.570 回答