Django:我想按最新评论/更新对帖子进行排序

时间:2018-11-21 13:04:34

标签: django sorting blogs

我在编写完教程后编写了一个简单的博客,到目前为止,它仍然有效。 但是现在,我想按帖子中的上一个活动对帖子列表进行排序。一旦发布新帖子或批准新评论,该帖子应位于列表顶部。 (它在论坛中的工作方式。)

这是我到目前为止所拥有的... (似乎可以按“ updated_date”对列表进行排序,但是在批准评论时将正确的日期时间附加到列表上会失败。)

非常感谢您的帮助

models.py

class Post(models.Model):
    author = models.ForeignKey('auth.User', on_delete=models.DO_NOTHING,)
    title = models.CharField(max_length=200)
    text = RichTextUploadingField()
    created_date = models.DateTimeField(default=timezone.now)
    published_date = models.DateTimeField(blank=True, null=True)
    updated_date = models.DateTimeField(blank=True, null=True)


    def publish(self):
        self.published_date = timezone.now()
        self.save()

    def __str__(self):
        return self.title

class Comment(models.Model):
    post = models.ForeignKey('blog.Post', related_name='comments', on_delete=models.DO_NOTHING,)
    author = models.CharField(max_length=200)
    text = models.TextField()
    created_date = models.DateTimeField(default=timezone.now)
    approved_comment = models.BooleanField(default=False)

    def approve(self):
        self.approved_comment = True
        Post.updated_date = timezone.now()
        self.save()

    def __str__(self):
        return self.text

def approved_comments(self):
    return self.comments.filter(approved_comment=True)

views.py

def post_list(request):
    posts = post.objects.filter(updated_date__lte=timezone.now()).order_by('-updated_date')
    return render(request, 'blog/post_list.html', {'posts': posts})

blog.views.post_detail


@login_required
def post_publish(request, pk):
    post = get_object_or_404(Post, pk=pk)
    post.publish()
    return redirect('post_detail', pk=pk)

def add_comment_to_post(request, pk):
    post = get_object_or_404(Post, pk=pk)
    if request.method == "POST":
        form = CommentForm(request.POST)
        if form.is_valid():
            comment = form.save(commit=False)
            comment.post = post
            comment.save()
            return redirect('post_detail', pk=post.pk)
    else:
        form = CommentForm()
    return render(request, 'blog/add_comment_to_post.html', {'form': form})


@login_required
def comment_approve(request, pk):
    comment = get_object_or_404(Comment, pk=pk)
    comment.approve()
    return redirect('post_detail', pk=comment.post.pk)

2 个答案:

答案 0 :(得分:0)

您可以使用aggregation尝试这样:

com.google.android.gms.ads.APPLICATION_ID
from django.db.models import Max Post.objects.filter(comments__approved_comment=True).annotate(max_activity=Max('comments__created_date')).order_by('max_activity', 'updated_date') 模型类中的

FYI approved_commentsapprove方法将不起作用。他们应该是这样的:

Comment

答案 1 :(得分:0)

Comment.approve()中,您将updated_date附加到Post的类,而不是与注释相关的实例。更新日期时,您应该使用self.post

def approve(self):
    self.approved_comment = True
    self.post.updated_date = timezone.now()
    self.save()