Я думал, что это может быть достигнуто с помощью функции .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/
Вы не должны сделать `class` или` id` атрибут только номер. Они не должны начинаться с числа. – alex 2010-11-23 01:36:22
Это хорошая информация. Я исправлю это thx. – CyberJunkie 2010-11-23 01:39:09