首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查找类和添加删除类

查找类和添加删除类
EN

Stack Overflow用户
提问于 2014-03-19 20:40:42
回答 3查看 60关注 0票数 0

我有一个以下格式的页面。

代码语言:javascript
复制
<% (1..3).each do %>
<div class="each-message-content notification-message-content">
 <div class="">
  <div class="">
  </div>
 </div>
 <div class="">
 </div>
 <div class="">
 </div>
</div>
<div class="">
</div>
<div class="read-unread">
</div>
<% end %>

单击read-unread,我将添加一个已读或未读的类。但是当我检查类是否有已读或未读的类时,它总是执行if块。切勿进入else块。我该怎么做呢?

代码语言:javascript
复制
 $(document).on('click','.read-unread', function(){
        var $read_unread = $(this).closest('.notification-message-content');
        if($read_unread.hasClass('unread')){
            $read_unread.removeClass('unread');
            $read_unread.addClass('read');                
        } else if (($read_unread.hasClass('read'))){
            $read_unread.removeClass('read');
            $read_unread.addClass('unread');

        }

    });
EN

回答 3

Stack Overflow用户

发布于 2014-03-19 20:49:38

使用明确的选择器可能会更好。

代码语言:javascript
复制
$(document).on('click','.read-unread', function(){
    $(this).prev().prev().toggleClass('read unread');   ;
});

请注意,'read‘/ 'unread’类中的一个需要已经存在。

票数 1
EN

Stack Overflow用户

发布于 2014-03-19 20:43:28

试试这个:

代码语言:javascript
复制
$(document).on('click', '.read-unread', function () {
    var $read_unread = $(this).prevAll('.notification-message-content').first();
    $read_unread.toggleClass('unread read');
});
票数 0
EN

Stack Overflow用户

发布于 2014-03-19 20:51:34

.closest()查找DOM树。.notification-message-content不在树上,它与.read-unread在同一级别。既然我们知道它在上面,你可以写

代码语言:javascript
复制
var $read_unread = $(this).prevAll('.notification-message-content');

它将查看树中所有之前的兄弟项。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22506142

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档