Ответ 1
Просто подключи и играй:
RedditStyleVoting
Реализация голосования в стиле reddit для любой модели с голосованием django
http://code.google.com/p/django-voting/wiki/RedditStyleVoting
Я создаю небольшое приложение, которое позволяет пользователям проголосовать за элементы вверх или вниз. Я использую Django (и новичок в этом!).
Мне просто интересно, какой лучший способ представить ссылку upvote пользователю. Как ссылку, кнопку или что-то еще?
Я уже делал что-то подобное в php с другой структурой, но я не уверен, могу ли я сделать то же самое. Должен ли я иметь метод для голосования вверх/вниз, а затем отображать ссылку на пользователя для клика. Когда они нажимают на него, он выполняет метод и обновляет страницу?
Просто подключи и играй:
RedditStyleVoting
Реализация голосования в стиле reddit для любой модели с голосованием django
http://code.google.com/p/django-voting/wiki/RedditStyleVoting
Вот суть моего решения. Я использую изображения с jQuery/AJAX для обработки кликов. Сильное влияние на этот сайт. Там некоторые вещи, которые могут использовать некоторые работы (например, обработка ошибок в клиенте - и многое из них, вероятно, будет реорганизована), но, надеюсь, код вам будет полезен.
HTML:
<div class="vote-buttons">
{% ifequal thisUserUpVote 0 %}
<img class="vote-up" src = "images/vote-up-off.png" title="Vote this thread UP. (click again to undo)" />
{% else %}
<img class="vote-up selected" src = "images/vote-up-on.png" title="Vote this thread UP. (click again to undo)" />
{% endifequal %}
{% ifequal thisUserDownVote 0 %}
<img class="vote-down" src = "images/vote-down-off.png" title="Vote this thread DOWN if it is innapropriate or incorrect. (click again to undo)" />
{% else %}
<img class="vote-down selected" src = "images/vote-down-on.png" title="Vote this thread DOWN if it is innapropriate or incorrect. (click again to undo)" />
{% endifequal %}
</div> <!-- .votebuttons -->
jQuery:
$(document).ready(function() {
$('div.vote-buttons img.vote-up').click(function() {
var id = {{ thread.id }};
var vote_type = 'up';
if ($(this).hasClass('selected')) {
var vote_action = 'recall-vote'
$.post('/ajax/thread/vote', {id:id, type:vote_type, action:vote_action}, function(response) {
if (isInt(response)) {
$('img.vote-up').removeAttr('src')
.attr('src', 'images/vote-up-off.png')
.removeClass('selected');
$('div.vote-tally span.num').html(response);
}
});
} else {
var vote_action = 'vote'
$.post('/ajax/thread/vote', {id:id, type:vote_type, action:vote_action}, function(response) {
if (isInt(response)) {
$('img.vote-up').removeAttr('src')
.attr('src', 'images/vote-up-on.png')
.addClass('selected');
$('div.vote-tally span.num').html(response);
}
});
}
});
Представление Django, обрабатывающее запрос AJAX:
def vote(request):
thread_id = int(request.POST.get('id'))
vote_type = request.POST.get('type')
vote_action = request.POST.get('action')
thread = get_object_or_404(Thread, pk=thread_id)
thisUserUpVote = thread.userUpVotes.filter(id = request.user.id).count()
thisUserDownVote = thread.userDownVotes.filter(id = request.user.id).count()
if (vote_action == 'vote'):
if (thisUserUpVote == 0) and (thisUserDownVote == 0):
if (vote_type == 'up'):
thread.userUpVotes.add(request.user)
elif (vote_type == 'down'):
thread.userDownVotes.add(request.user)
else:
return HttpResponse('error-unknown vote type')
else:
return HttpResponse('error - already voted', thisUserUpVote, thisUserDownVote)
elif (vote_action == 'recall-vote'):
if (vote_type == 'up') and (thisUserUpVote == 1):
thread.userUpVotes.remove(request.user)
elif (vote_type == 'down') and (thisUserDownVote ==1):
thread.userDownVotes.remove(request.user)
else:
return HttpResponse('error - unknown vote type or no vote to recall')
else:
return HttpResponse('error - bad action')
num_votes = thread.userUpVotes.count() - thread.userDownVotes.count()
return HttpResponse(num_votes)
И соответствующие части модели Thread:
class Thread(models.Model):
# ...
userUpVotes = models.ManyToManyField(User, blank=True, related_name='threadUpVotes')
userDownVotes = models.ManyToManyField(User, blank=True, related_name='threadDownVotes')
Что бы вы ни делали, убедитесь, что он отправлен POST, а не GET; Запросы GET никогда не должны изменять информацию о базе данных.
Как ссылка, кнопка или что-то еще?
Что-то еще, как насчет изображения?
Когда они нажимают на него, он выполняет метод и обновляет страницу?
Возможно, вы могли бы лучше использовать ajax для вызова метода для сохранения голоса и вообще ничего не обновлять.
Это то, что приходит мне на ум.