Я добавил модель Like, но не знаю, как увеличить количество Like.
Я создал приложение Блог, и я хочу добавить кнопку Like к каждой записи в блоге, как я могу это сделать? Как я могу сделать это в представлении и шаблоне?
модели:
class Like(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
post = models.ForeignKey(Photo, on_delete=models.CASCADE)
def __str__(self):
return str(self.user)
взгляд:
def viewPhoto(request, pk):
post = get_object_or_404(Photo, id=pk)
photo = Photo.objects.get(id=pk)
return render(request, 'photo.html', {'photo': photo, 'post': post })
Для того, чтобы использовать подобную функциональность, вы делаете что-то вроде этого, но я надеюсь, вы знаете, как работать с фронтендом, в вашем html?
def like(request, pk):
post = Photo.objects.get(pk=pk)
liked= False
like = Like.objects.filter(username=request.user, post=post)
if like:
like.delete()
else:
liked = True
Like.objects.create(username=request.user, post=post)
resp = {
'liked':liked
}
response = json.dumps(resp)
return redirect('') # redirect to any url after the object has been liked
return HttpResponse(response,content_type = "application/json")
Вам нужно будет поместить понравившийся объект в любое представление, которое предпочтет иметь функцию like:
def viewPhoto(request, pk):
post = get_object_or_404(Photo, id=pk)
photo = Photo.objects.get(id=pk)
liked = [i for i in Photo.objects.all() if Like.objects.filter(username =
request.user, post=i)]
return render(request, 'photo.html', {'photo': photo, 'post': post ,'liked':liked})
Html шаблон это просто чтобы дать вам идею о том, как сделать это в вашем html, поскольку я не знаю, какой тип скрипта или css вы используете. поэтому кнопка может не выглядеть как большой палец в вашем случае.
<button class="btn btn-white mr-3 like" id="{{ post.id }}">
{% if post in liked %}
<a href="{% url 'blog:like' post.pk %}" id="likebtn{{ post.pk }}"
class="flex items-center space-x-2">
<div> Unlike</div>
</a>
{% else %}
<a href="{% url 'blog:like' post.pk %}" id="likebtn{{ post.pk }}" class="flex items-center space-x-2">
<div>Like</div>
</a>
{% endif %}
</button>