我有一个跟随器系统,它是用ajax执行的.问题是“关注者”按钮不起作用.并不是点击,一天结束时用户数量的关注者数量不会增加.我下面有我的代码
模板
{% with objects=user.followers.count %}
<span class="count">
<span class="total">
{{ objects }}
</span>
follower{{ objects|pluralize }}
</span>
<a href="#" data-id="{{ user.id }}" data-action="{% if request.user in user.followers.all %}un{% endif %}follow" class="follow button">
{% if request.user not in user.followers.all %}
Follow
{% else %}
Unfollow
{% endif %}
</a>
{% block query %}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<script src=" http://cdn.jsdelivr.net/jquery.cookie/1.4.1/jquery.cookie.min.js "></script>
<script>
var csrftoken = $.cookie('csrftoken'); function csrfSafeMethod(method) {
// these HTTP methods do not require CSRF protection
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method)); }
$.ajaxSetup({
beforeSend: function(xhr, settings) {
if (!csrfSafeMethod(settings.type) && !this.crossDomain) { xhr.setRequestHeader("X-CSrftoken", csrftoken);
} }
});
$(document).ready(function(){
$('a.follow').click(function(e){
e.preventDefault();
$.post('{% url "user_follow" %}',
{
id: $(this).data('id'), action: $(this).data('action')
}, function(data){
if (data['status'] == 'ok') {
var prevIoUs_action = $('a.follow').data('action');
// toggle data-action $('a.follow').data('action',
prevIoUs_action == 'follow' ? 'unfollow' : 'follow'); // toggle link text
$('a.follow').text(
prevIoUs_action == 'follow' ? 'Unfollow' : 'Follow');
// update total followers
var prevIoUs_followers = parseInt(
$('span.count .total').text());
$('span.count .total').text(prevIoUs_action == 'follow' ? prevIoUs_followers + 1 : prevIoUs_followers - 1);
} }
); });
}); </script>
{% endblock %}
然后我在base.html中提供了块查询
Views.py
def user_follow(request):
user_id = request.POST.get('id')
action = request.POST.get('action')
if user_id and action:
try:
user = User.objects.get(id=user_id)
if action == 'unfollow':
Contact.objects.get_or_create( user_from=request.user, user_to=user)
else:
Contact.objects.filter(user_from=request.user,user_to=user).delete()
return JsonResponse({'status':'ok'})
except User.DoesNotExist:
return JsonResponse({'status':'ko'})
return JsonResponse({'status':'ko'})
如果需要任何帮助,将提供进一步的代码.
解决方法:
def user_follow(request):
user_id = request.POST.get('id', None)
action = request.POST.get('action', '')
FOLLOW_ACTION = 'follow'
UNFOLLOW_ACTION = 'unfollow'
if request.user.is_anonymous:
return JsonResponse({
'status':'ko',
'message': 'You must login'}
)
if action not in [FOLLOW_ACTION, UNFOLLOW_ACTION]:
return JsonResponse({
'status':'ko',
'message': 'UnkNown action {}'.format(action)}
)
try:
user = User.objects.get(id=user_id)
if action == UNFOLLOW_ACTION:
Contact.objects.filter(user_from=request.user,user_to=user).delete()
return JsonResponse({
'status':'ok'
})
else:
contact, created = Contact.objects.get_or_create( user_from=request.user, user_to=user)
return JsonResponse({
'status':'ok',
'message': 'Following id : {}'.format(contact.id)
})
except User.DoesNotExist:
return JsonResponse({
'status':'ko'
'message': 'user id: does not exist: {}'.format(user_id)
})
您将关注和取消关注混为一谈,如果取消关注则创建联系人.
模板:
{% if request.user != user %}
<a> Follow ....
{% endif %}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。