开发者

JQuery .Parent()

开发者 https://www.devze.com 2022-12-16 22:44 出处:网络
Ok here is my HTML (One row of about 20) <tr class=\"post-unauth message-unread\"> <td> <input class=\"check-read\" type=\"checkbox\" ch开发者_如何学Pythonecked=\"checked\" value=\"68\

Ok here is my HTML (One row of about 20)

<tr class="post-unauth message-unread">
  <td>
    <input class="check-read" type="checkbox" ch开发者_如何学Pythonecked="checked" value="68"/>
  </td>
  <td class="message-description" title="Post Title">
  </td>
  <td class="message-author">Name</td>
  <td class="message-dates">3 hours ago</td>
  <td class="message-commentcount" title="0 comment(s)">
  </td>
</tr>

Now when the checkbox is clicked I need to change the class of the parent

$('.check-read').click(function() {
         $(this).parent().parent().removeClass('message-unread').addClass('message-read');
});

I'm missing somthing obvious I think as this doesnt work (Doesnt error) but nothing changes.

I even tried setting the CSS background color and no change to the HTML.

Any suggestions?


I think you should try closest. This is new in jQuery 1.3

$(this).closest("tr").removeClass('message-unread').addClass('message-read');

closest docs

As Mark mentions in the comment below, using a class would be more suitable here since it is less likely to be affected by changes in your table structure.

 $(this).closest(".message_row").removeClass('message-unread').addClass('message-read');

And then add "message_row" to your tr. If an unchecked box is guaranteed to have message-unread class then you can use it for your selector instead of adding a message_row class and selecting on it.


Just to offer an alternative solution. In cases like this, I prefer to attach the click to the TR and then let the click event of all the child elements bubble up to the TR. You could do something like this:

$(".classForEachPost").click(function(e){
    var $target = $(e.target);
    var $this = $(this);

    if($target.is(".check-read:checkbox")){
       $this.removeClass("message-unread").addClass("message-read");
    }

    // check for other click events in the TR you might want to act upon
});

I like this pattern when there are a lot of actions in a row, div, etc. It stops a lot of traversing up and down the graph and centralizes all the event handles in one place. It makes it a lot easier for me to wrap that in a jQuery plugin.

$.fn.myPostRow = function(){
    this.click(function(e){
        // same code as above
    }
};

Then you have a plugin for the entire row that you could just call like:

$(".tableOfPosts TR").myPostRow();

This would be the only JavaScript mixed in with the HTML markup and the plugin can be moved to a JS file.

The answer completely digressed from your initial question, but hopefully it is still useful.

0

精彩评论

暂无评论...
验证码 换一张
取 消