2010-11-23 4 views
1

Я думал, что это может быть достигнуто с помощью функции .prev(), но по какой-то причине она не работает.Функция jquery для отдельных divs

Я создаю большие пальцы вверх/вниз для сообщений в блоге. Я пытаюсь отображать сообщения в соответствии с тем, что голосует пользователь. Либо ВВЕРХ, либо ВНИЗ, но всякий раз, когда я проголосую за 1 конкретное сообщение, сообщение появляется для всего сообщения.

Это мой код. Я удалил попытки prev() сделать его более читаемым. Скрипт отлично работает ajax.

$(document).ready(function() { 
    $(".vote_button").click(function(e) { //the UP or DOWN vote button 
    var vote_status = $(this).attr('class').split(' ')[1]; //gets second class name following vote_button 
    var vote_post_id = $(this).attr("id"); //the post ID 
    var dataString = 'post_id=' + vote_post_id + '&vote_status=' + vote_status; 

    $.ajax({ 
     type: "POST", 
     url: "url/add_vote.php", 
     data: dataString, 
     cache: false, 
     success: function(html) { 
      if (vote_status == 1) 
     { 
       $('.msg_box').fadeIn(200); 
       $('.msg_box').text('You voted UP!'); 
      } 
      if (vote_status == 2) 
     { 
       $('.msg_box').fadeIn(200); 
       $('.msg_box').text('You voted DOWN!'); 
      } 
     } 
    }); 
    return false; 
}); 
}); 

Образец HTML

<div class="vote_button 1" id="18">UP</div> 
<div class="vote_button 2" id="77">DOWN</div> 
<div class="msg_box"></div> 

<div class="vote_button 1" id="43">UP</div> 
<div class="vote_button 2" id="15">DOWN</div> 
<div class="msg_box"></div> 


<div class="vote_button 1" id="11">UP</div> 
<div class="vote_button 2" id="78">DOWN</div> 
<div class="msg_box"></div> 

EDIT: Предоставлено jsfiddle без Ajax части http://jsfiddle.net/XJeXw/

+1

Вы не должны сделать `class` или` id` атрибут только номер. Они не должны начинаться с числа. – alex 2010-11-23 01:36:22

+0

Это хорошая информация. Я исправлю это thx. – CyberJunkie 2010-11-23 01:39:09

ответ

5

Вам необходимо сохранить ссылку на кнопку внутри click обработчика (например, var me = $(this);), а затем использовать me.nextAll('.msg_box:first') внутри обработчика AJAX.

EDIT: Example:

var me = $(this); //The this will be different inside the AJAX callback 

$.ajax({ 
    type: "POST", 
    url: "url/add_vote.php", 
    data: dataString, 
    cache: false, 
    success: function(html) { 
     me.nextAll('.msg_box:first') 
      .text(vote_status == 1 ? 'You voted UP!' : 'You voted DOWN!') 
      .fadeIn(200); 
    } 
}); 
Смежные вопросы